news 2026/6/15 19:27:35

苏旭晖先生写的纯SQL求解Advent of Code 2025第9题 最大矩形面积 第2部分

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
苏旭晖先生写的纯SQL求解Advent of Code 2025第9题 最大矩形面积 第2部分

原贴地址,我把它改成了能在DuckDB运行,主要是把connect by level 改为 range函数

-- 去除match_recognize, 就是合并连续区间的老套路:withday9as(selectrow_number()over()id,t.*fromread_csv('2509-input.txt',header=0)t(x,y)),vas(selectday9.*,count(*)over()ascntfromday9),sas(----------轮廓线段selectd1.idassid,d1.cnt,casewhend1.x=d2.xthen'X'else'Y'endass_direction,casewhend1.x=d2.xthend1.xelsed1.yendass_val,casewhend1.x=d2.xthenleast(d1.y,d2.y)elseleast(d1.x,d2.x)endass_v1,casewhend1.x=d2.xthengreatest(d1.y,d2.y)elsegreatest(d1.x,d2.x)endass_v2fromv d1,v d2whered2.id=d1.id+1or(d2.id=1andd1.id=d2.cnt)),ssas(------------ s1 和 s2分别是轮廓线s在起点和终点折了一次之后再回到和s平行的另外两端轮廓线(所以sid会间隔)。----------- 如果S和S1(或S和S2)构成Z字形则,则方向没有改变,在和那个端点的垂直线相交时,两段只算一段(通过least使得这两段值一样,dense_rank()把它们分到一组)----------- 如果S和S1(或S和S2)构成U字形则,则方向改变,分别算做两段,所以各自保留自己的s_valselects.*,casewhens.s_v1in(s1.s_v1,s2.s_v1)thens.s_valwhens.s_v1=s1.s_v2thenleast(s.s_val,s1.s_val)whens.s_v1=s2.s_v2thenleast(s.s_val,s2.s_val)endass_val1----- 当s的v1端点落在垂直线上时,用这个代替s_val来排序,casewhens.s_v2in(s1.s_v2,s2.s_v2)thens.s_valwhens.s_v2=s1.s_v1thenleast(s.s_val,s1.s_val)whens.s_v2=s2.s_v1thenleast(s.s_val,s2.s_val)endass_val2----- 当s的v2端点落在垂直线上时,用这个代替s_val来排序froms,s s1,s s2wherecasewhens.sid>s.cnt-2thens.sid+2-s.cntelses.sid+2end=s1.sidandcasewhens.sid<3thens.sid-2+s.cntelses.sid-2end=s2.sid),e2as(selects_direction,s_val,s_v1,s_v2,CASEWHENs_v1<=MAX(s_v2)OVER(PARTITIONBYs_direction,s_valorderbys_v1,s_v2ROWSBETWEENUNBOUNDEDPRECEDINGAND1PRECEDING)+1then0else1endasflagfrom(selects_direction,s_val,min(val2)s_v1,max(val2)s_v2from(selecta.s_direction,a.s_val,ss.s_val val2,dense_rank()over(partitionbya.s_direction,a.s_valorderbycasea.s_valwhenss.s_v1thenss.s_val1whenss.s_v2thenss.s_val2elsess.s_valend)rnfrom(selectdistincts_direction,s_valfroms)ajoinssona.s_direction<>ss.s_directionanda.s_valbetweenss.s_v1andss.s_v2)groupbys_direction,s_val,ceil(rn/2)unionallselects_direction,s_val,s_v1,s_v2froms)),eas(select/*+ materialize */s_direction,s_val,min(s_v1)s_v1,max(s_v2)s_v2from(selecte2.*,sum(flag)over(partitionbys_direction,s_valorderbys_v1)grpfrome2)groupbys_direction,s_val,grp),ras(------- 找出所有矩形,并拆成四条边selectd1.x x1,d1.y y1,d2.x x2,d2.y y2,casewhennin(1,2)then'X'else'Y'endasr_direction,casenwhen1thenleast(d1.x,d2.x)when2thengreatest(d1.x,d2.x)when3thenleast(d1.y,d2.y)when4thengreatest(d1.y,d2.y)endasr_val,casewhennin(1,2)thenleast(d1.y,d2.y)elseleast(d1.x,d2.x)endasr_v1,casewhennin(1,2)thengreatest(d1.y,d2.y)elsegreatest(d1.x,d2.x)endasr_v2fromday9 d1,day9 d2,(selecti nfromrange(1,5)t(i))whered1.id<d2.idandd1.x<>d2.xandd1.y<>d2.y)select*from(selectx1,y1,x2,y2,(abs(x1-x2)+1)*(abs(y1-y2)+1)areafromrwhereexists(select1fromewherer.r_direction=e.s_directionandr.r_val=e.s_valandr.r_v1betweene.s_v1ande.s_v2andr.r_v2betweene.s_v1ande.s_v2)groupbyx1,y1,x2,y2havingcount(*)=4----- 四条边都在多边形内)orderbyareadesclimit1;-- fetch first row with ties;

这个版本比调用spatial插件的版本快了10倍。

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/15 11:49:47

开发的一些知识

1.单例和工厂函数区别维度单例工厂&#xff08;无缓存&#xff09;内存一份实例 一份连接池每实例独立内存 独立连接池连接池共享&#xff0c;TCP 复用各建各的&#xff0c;易打满文件描述符CPU初始化一次每次都要构造 可能的 TLS 握手GC 压力无实例用完才回收&#xff0c;高…

作者头像 李华
网站建设 2026/6/15 13:55:36

NPP 热带森林:美属维尔京群岛肉桂湾,1982-1993 年,R1

NPP Tropical Forest: Cinnamon Bay, U.S. Virgin Islands, 1982-1993, R1 简介 该数据集包含三个 ASCII 文件&#xff08;.txt 格式&#xff09;。其中一个数据文件包含基于 16 个永久样地&#xff08;位于美属维尔京群岛圣约翰岛 132 公顷的肉桂湾流域内&#xff0c;沿海拔…

作者头像 李华
网站建设 2026/6/15 13:06:04

利用gpt-oss-20b构建企业级智能客服系统的技术路径

利用 gpt-oss-20b 构建企业级智能客服系统的技术路径 在客户对服务响应速度和专业性要求日益提升的今天&#xff0c;传统客服模式正面临巨大挑战。人工坐席成本高、响应慢&#xff0c;而基于规则的聊天机器人又难以理解复杂语义&#xff0c;常常陷入“答非所问”的尴尬境地。与…

作者头像 李华
网站建设 2026/6/15 11:46:51

LS-DYNA许可证常见问题及解决方案

在科研和工程领域&#xff0c;LS-DYNA因其强大的有限元分析能力而受到广泛欢迎。然而&#xff0c;对于许多用户来说&#xff0c;许可证问题可能是一个常见的挑战。本文旨在解答有关LS-DYNA许可证的常见问题&#xff0c;并提供相应的解决方案&#xff0c;以帮助您更好地使用和管…

作者头像 李华
网站建设 2026/6/15 13:50:53

AI如何帮你掌握Vue.js的$set方法

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 创建一个Vue.js示例项目&#xff0c;展示如何使用$set方法动态添加响应式属性。项目应包含一个简单的用户界面&#xff0c;允许用户添加新的数据属性到现有对象中&#xff0c;并实时…

作者头像 李华