news 2026/6/10 18:15:45

苏旭晖先生写的纯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/10 16:06:55

GitHub星标过万的Qwen3-VL-8B项目实战合集

Qwen3-VL-8B&#xff1a;轻量多模态落地的破局者 在AI模型参数竞赛愈演愈烈的今天&#xff0c;一个反向而行的技术路径正悄然崛起——不是追求千亿级“巨无霸”&#xff0c;而是打磨80亿参数级别的“精悍战士”。通义千问团队推出的 Qwen3-VL-8B 正是这一理念的典型代表。它没有…

作者头像 李华
网站建设 2026/6/10 16:14:09

Linux MAC层实现机制深度剖析

Linux MAC层实现机制深度剖析 1. MAC层在网络协议栈中的战略定位 1.1 网络世界的 “交通管理局” 想象一下, 如果网络世界是一个庞大的城市交通系统, 那么MAC&#xff08;Media Access Control&#xff09;层就是这座城市的交通管理局. 它位于OSI模型的第二层&#xff08;数据链…

作者头像 李华
网站建设 2026/6/10 9:29:49

清华源配置Miniconda后仍慢?检查这5个网络设置

清华源配置Miniconda后仍慢&#xff1f;检查这5个网络设置 在人工智能项目开发中&#xff0c;一个常见的场景是&#xff1a;你已经按照教程将 Miniconda 配置为使用清华大学镜像源&#xff0c;信心满满地运行 conda install pytorch&#xff0c;结果命令行却卡在“Solving env…

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

基于SpringBoot2+Vue2的行业知识答题考试系统

行业知识答题考试系统 演示视频 https://www.bilibili.com/video/BV1J8m1BjEuE/ 角色 管理员、考生 技术 SpringBoot2, Vue2, MySQL 核心功能 本系统是一个行业知识答题考试系统&#xff0c;旨在提供一个完整的在线考试解决方案。核心价值在于实现题库的集中管理、试卷…

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

从零搭建高可用VPS集群:实战案例分享

快速体验 打开 InsCode(快马)平台 https://www.inscode.net输入框内输入如下内容&#xff1a; 开发一个分步指南工具&#xff0c;帮助用户搭建一个由3个VPS节点组成的负载均衡集群。工具应自动生成配置脚本&#xff08;Nginx负载均衡、数据库主从复制、Redis缓存等&#xff09…

作者头像 李华
网站建设 2026/6/10 17:41:00

GPT-OSS-20B本地部署全攻略:基于清华镜像站快速拉取模型

GPT-OSS-20B本地部署全攻略&#xff1a;基于清华镜像站快速拉取模型 在大语言模型席卷各行各业的今天&#xff0c;越来越多开发者开始尝试将AI能力“搬回家”——不是调用云端API&#xff0c;而是真正在自己的笔记本、工作站甚至实验室老旧PC上跑起一个能对话、会写代码、懂逻辑…

作者头像 李华