news 2026/4/7 10:39:15

苏旭晖先生写的纯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/4/3 0:04:04

Virtual DOM 的 Diff 算法演进:从 Vue 的双端比较到 React 的单端链表遍历

各位同学&#xff0c;大家好&#xff01;今天我们来深入探讨前端框架中一个至关重要的核心技术&#xff1a;虚拟DOM的Diff算法。这个算法的效率高低&#xff0c;直接决定了我们应用渲染性能的上限。我们将沿着历史的脉络&#xff0c;对比分析Vue 2.x时代经典的双端比较算法&…

作者头像 李华
网站建设 2026/4/4 19:26:02

dify智能体平台性能压测报告:vLLM胜出

vLLM为何在dify智能体平台压测中胜出&#xff1f; 在构建现代AI应用的今天&#xff0c;一个核心挑战浮出水面&#xff1a;如何让大语言模型既快又稳地服务成千上万的并发用户&#xff1f;尤其是在像 dify智能体平台 这样需要支持多轮对话、长上下文记忆和实时响应的系统中&…

作者头像 李华
网站建设 2026/4/1 12:34:00

k8s-网络

Kubernetes (K8s) 网络解决方案是指在 Kubernetes 集群中实现容器网络通信的各种技术和工具。这些解决方案的设计目的是为了满足 Kubernetes 网络模型的要求&#xff0c;即&#xff1a;所有 Pod 都必须能够无需 NAT 就能互相通信。所有节点必须能够无需 NAT 就能与所有 Pod 通信…

作者头像 李华
网站建设 2026/4/1 22:20:40

刷视频赚钱

周末有个粉丝问我&#xff1a;独孤&#xff0c;我天天刷干货、学认知&#xff0c;为什么还是穷&#xff1f;我回他一句话&#xff1a;你不是在学习&#xff0c;你是在缓急焦虑。刷信息那一刻&#xff0c;你就已经站错了位置。成功的人&#xff0c;从不做信息的消费者。大多数人…

作者头像 李华
网站建设 2026/4/2 21:44:02

SQL Server 2008 R2中NVARCHAR(MAX)与NTEXT区别

在 SQL Server 2008 R2 中&#xff0c;NVARCHAR(MAX) 和 NTEXT 都用于存储 Unicode 文本数据&#xff0c;但存在重要区别&#xff1a;主要区别1. 版本支持NTEXT: 已过时&#xff0c;SQL Server 2005 及以后版本不推荐使用NVARCHAR(MAX): 推荐使用&#xff0c;是 NTEXT 的现代替…

作者头像 李华
网站建设 2026/4/3 9:19:22

二十一、【鸿蒙 NEXT】分词和汉字转拼音

【前言】 在某些功能场景&#xff0c;比如实现一个本地搜索功能时&#xff0c;可能需要支持中文搜索&#xff0c;同时支持拼音搜索。这里就会涉及到两个功能点&#xff0c;一个是中文转拼音&#xff0c;一个是将中文进行分词。同时这里有个注意点如果调用系统接口进行批量分词…

作者头像 李华