news 2026/4/16 15:24:53

LeetCode 每日一题 2025/12/8-2025/12/14

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
LeetCode 每日一题 2025/12/8-2025/12/14

LeetCode 每日一题 2025/1/1-2025/1/7
记录了初步解题思路 以及本地实现代码;并不一定为最优 也希望大家能一起探讨 一起进步


目录

      • 12/8 1925. 统计平方和三元组的数目
      • 12/9 3583. 统计特殊三元组
      • 12/10 3577. 统计计算机解锁顺序排列数
      • 12/11 3531. 统计被覆盖的建筑
      • 12/12 3433. 统计用户被提及情况
      • 12/13
      • 12/14


12/8 1925. 统计平方和三元组的数目

遍历
如果a2+b2=c^2
a一定不等于b
假设a<b<c (a,b,c) (b,a,c)都满足
所以找到一组ans+2

defcountTriples(n):""" :type n: int :rtype: int """importmath ans=0forainrange(1,n):forbinrange(a+1,n):c=int(math.sqrt(a**2+b**2))ifc<=nandc**2==a**2+b**2:ans+=2returnans

12/9 3583. 统计特殊三元组

从右到左枚举j
左侧每个数出现的次数放入left 右侧每个数出现次数放入right
当前nums[j] 两边nums[j]*2 的个数相乘

defspecialTriplets(nums):""" :type nums: List[int] :rtype: int """fromcollectionsimportdefaultdict MOD=10**9+7left=defaultdict(int)right=defaultdict(int)n=len(nums)foriinrange(n-1):left[nums[i]]+=1right[nums[-1]]+=1ans=0fornuminnums[-2:0:-1]:left[num]-=1ans=(ans+left[num*2]*right[num*2])%MOD right[num]+=1returnans

12/10 3577. 统计计算机解锁顺序排列数

如果能够全部解锁那么complexity[0]必定最小
即如果存在complexity[i]<=complexity[0] 这个i无法解锁 答案为0
否则答案为(n-1)!

defcountPermutations(complexity):""" :type complexity: List[int] :rtype: int """MOD=10**9+7n=len(complexity)foriinrange(1,n):ifcomplexity[i]<=complexity[0]:return0ans=1foriinrange(2,n):ans=(ans*i)%MODreturnans

12/11 3531. 统计被覆盖的建筑

记录每一行每一列出现建筑的最小位置和最大位置
遍历半段当前x,y是否都在最小位置和最大位置之间

defcountCoveredBuildings(n,buildings):""" :type n: int :type buildings: List[List[int]] :rtype: int """rowmin=[n+1]*(n+1)colmin=[n+1]*(n+1)rowmax=[0]*(n+1)colmax=[0]*(n+1)forx,yinbuildings:rowmin[y]=min(rowmin[y],x)rowmax[y]=max(rowmax[y],x)colmin[x]=min(colmin[x],y)colmax[x]=max(colmax[x],y)ans=0forx,yinbuildings:ifrowmin[y]<x<rowmax[y]andcolmin[x]<y<colmax[x]:ans+=1returnans

12/12 3433. 统计用户被提及情况

按时间顺序先排序
遍历每一个event
nxtonline[i]记录用户i下一次上线的时间
分情况处理

defcountMentions(numberOfUsers,events):""" :type numberOfUsers: int :type events: List[List[str]] :rtype: List[int] """events.sort(key=lambdax:(int(x[1]),x[0]=="MESSAGE"))cnt=[0]*numberOfUsers nxtonline=[0]*numberOfUsersforevtinevents:cur=int(evt[1])ifevt[0]=="MESSAGE":ifevt[2]=="ALL":foriinrange(numberOfUsers):cnt[i]+=1elifevt[2]=="HERE":fori,tinenumerate(nxtonline):ift<=cur:cnt[i]+=1else:foriinevt[2].split():cnt[int(i[2:])]+=1else:nxtonline[int(evt[2])]=cur+60returncnt

12/13


12/14


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

三种方式打 Java 可执行 JAR 包,你用对了吗?

三种方式打 Java 可执行 JAR 包&#xff0c;你用对了吗&#xff1f;写完代码只是开始&#xff0c;如何打包成一个“开箱即用”的 JAR 文件&#xff0c;才是交付的关键一步。很多 Java 开发者都遇到过这样的问题&#xff1a; 本地跑得好好的程序&#xff0c;一打包就报错 ClassN…

作者头像 李华
网站建设 2026/4/16 9:35:18

05_C 语言进阶之避坑指南:编译器优化等级 —— 嵌入式开发中被忽略的 “隐形陷阱”

C 语言进阶之避坑指南:编译器优化等级 —— 嵌入式开发中被忽略的 “隐形陷阱” 一、编译器优化等级的 “坑”,你踩过吗? “代码在 O0 调试模式下运行正常,切换到 O2 优化后直接卡死?” “全局变量在优化后被编译器‘吃掉’,中断中修改的值主循环读不到?” “调试时…

作者头像 李华
网站建设 2026/4/16 5:57:56

别把数组当“流水账”:用 Summary Ranges 教你学会“结构化思考”

别把数组当“流水账”:用 Summary Ranges 教你学会“结构化思考” 作者:Echo_Wish 一、引子:我们处理的不是数组,是“信息结构化” 咱们聊一个特别小、但特别有味道的题目:汇总区间(Summary Ranges)。 这个题我第一次看到时,直觉觉得:“不就处理个数组嘛,这能有啥…

作者头像 李华
网站建设 2026/4/15 16:32:06

基础进制转换

m 进制转 n 进制&#xff08;通用实现&#xff09;m 进制转 n 进制的核心逻辑是以 10 进制为中间桥梁&#xff1a;先将 m 进制数转为 10 进制&#xff0c;再将 10 进制数转为 n 进制。该方法适配任意合法进制&#xff08;2 ≤ m,n ≤ 36&#xff09;&#xff0c;兼容数字 字母…

作者头像 李华
网站建设 2026/4/16 7:33:09

node基础

从node文档里抄了一些东西贴出来&#xff0c;省的每次都找好久&#xff08;node文档的那个目录&#xff0c;我感觉找东西挺费劲的&#xff09; &#xff08;ps:为什么node v25版本的文档里找不到path模块&#xff0c;v24版本的文档里找到了&#xff01;&#xff01;&#xff01…

作者头像 李华