news 2026/3/29 5:25:19

Leetcode 76.最小覆盖子串 JavaScript (Day 6)

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Leetcode 76.最小覆盖子串 JavaScript (Day 6)

js一刷法一(丑陋)

varminWindow=function(s,t){if(s.length<t.length)return"";letm=newSet(s);for(leti=0;i<t.length;i++){if(!m.has(t[i]))return"";}letans=[0,1000000000000000000];letidx=newMap();for(leti=0;i<t.length;i++){idx.set(t[i],(idx.get(t[i])??0)+1);}letleft=0,right=0;while(right<s.length){if(idx.has(s[right]))idx.set(s[right],idx.get(s[right])-1);while([...idx.values()].every(x=>x<=0)){if(left===right)returns[right];if(right-left<ans[1]-ans[0])ans=[left,right];if(idx.has(s[left]))idx.set(s[left],idx.get(s[left])+1);left++;}right++;}while([...idx.values()].every(x=>x<=0)){if(left===right)returns[right];if(right-left<ans[1]-ans[0])ans=[left,right];if(idx.has(s[left]))idx.set(s[left],idx.get(s[left])+1);left++;}if(ans[1]==1000000000000000000)return"";returns.slice(ans[0],ans[1]+1);};

js一刷法一(优化版)

varminWindow=function(s,t){if(s.length<t.length)return"";letneed=t.length;letmap=newMap();for(letcoft){map.set(c,(map.get(c)??0)+1);}letleft=0;letans=[0,Infinity];for(letright=0;right<s.length;right++){letc=s[right];if(map.has(c)){if(map.get(c)>0)need--;map.set(c,map.get(c)-1);}while(need===0){if(right-left<ans[1]-ans[0]){ans=[left,right];}letd=s[left];if(map.has(d)){map.set(d,map.get(d)+1);if(map.get(d)>0)need++;}left++;}}returnans[1]===Infinity?"":s.slice(ans[0],ans[1]+1);};

思路完全相同,只不过一开始我是想用之前一个题思路,先将t存入hash,然后遇到符合条件的就-1,优化后用need(t的长度)来记录,need=0时候,说明找到了
算法核心:左指针不动,右指针不断往右,当窗口里包含了所有符合条件的字符后,从左边缩短窗口,左指针右移,所以说left在right动之前,永远指向的是有效字符,因为无效的在循环中清除了

js一刷法二(无敌)

varminWindow=function(s,t){constarr=newArray(128).fill(0);for(constioft){arr[i.charCodeAt(0)]--;}letleft=0,right=0,count=0,start=-1;letlen=s.length+1;while(right<s.length){if(arr[s.charCodeAt(right)]<0){count++;}arr[s.charCodeAt(right)]++;while(left<=right&&arr[s.charCodeAt(left)]>0){arr[s.charCodeAt(left)]--;left++;}if(count===t.length&&right-left+1<len){len=right-left+1;start=left;}right++;}returnstart===-1?"":s.slice(start,start+len);};

算法核心:长度可变的滑动窗口,因为字符串中数字大小写字母不方便来比较,所以全部转化成ASCII码来比较,创建一个长度为128的数组,对应0-127的ASCII码,可以表示26个大小写字母,0-9的数字
数组中

>0 无效元素
=0 符合要求,刚好在窗口内
<0 不在窗口内

先把数组全部初始化为0,要找的字符全部初始化为-1,然后向右遍历,并+1,原来为-1的加一后变为0,为在窗口内的有效字符,无用的字符和有用但重复的字符+1后>0,在后续的循环中可以被清除
用start记录起点 用len来更新长度,找到最小的len

语法注意点:
想要获取数组/字符串arr中的一部分,并且不破坏原数组,用slice(i,j),可以将arr[i]~arr[j-1]存储在新数组中并返回

arr.charCodeAt[i] 将arr[i]转化成ASCII码

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

PyTorch-CUDA镜像中的CUDA工具包版本说明及兼容性分析

PyTorch-CUDA镜像中的CUDA工具包版本说明及兼容性分析 在现代深度学习研发中&#xff0c;一个常见的场景是&#xff1a;研究人员在本地训练好的模型&#xff0c;部署到服务器后却因环境差异导致运行失败。这种“在我机器上能跑”的问题&#xff0c;曾长期困扰着AI团队的协作效率…

作者头像 李华
网站建设 2026/3/20 1:31:29

GitHub热门推荐:PyTorch-CUDA-v2.7镜像助力AI开发者提速50%

PyTorch-CUDA-v2.7 镜像&#xff1a;如何让 AI 开发效率飙升 50%&#xff1f; 在当今 AI 研发一线&#xff0c;你有没有遇到过这样的场景&#xff1f;刚接手一个项目&#xff0c;兴冲冲地准备跑通代码&#xff0c;结果 torch.cuda.is_available() 返回了 False。排查两小时才发…

作者头像 李华
网站建设 2026/3/23 21:51:01

无需繁琐配置!PyTorch-CUDA-v2.7镜像开箱即用GPU训练

无需繁琐配置&#xff01;PyTorch-CUDA-v2.7镜像开箱即用GPU训练 在深度学习项目中&#xff0c;最让人头疼的往往不是模型设计或调参&#xff0c;而是环境搭建——尤其是当你满心期待地准备开始训练时&#xff0c;却发现 torch.cuda.is_available() 返回了 False。明明装了NVID…

作者头像 李华
网站建设 2026/3/15 19:15:38

DiskInfo温控监测:防止PyTorch训练导致硬盘过热

DiskInfo温控监测&#xff1a;防止PyTorch训练导致硬盘过热 在深度学习模型训练日益常态化的今天&#xff0c;我们往往把注意力集中在GPU利用率、显存瓶颈和训练速度上。然而&#xff0c;在一场持续数天的PyTorch大规模训练任务中&#xff0c;真正让系统突然“罢工”的&#xf…

作者头像 李华
网站建设 2026/3/27 3:18:54

清华镜像源支持IPv6访问:提升PyTorch下载速度

清华镜像源支持IPv6访问&#xff1a;提升PyTorch下载速度 在高校和科研机构的AI开发一线&#xff0c;你是否也经历过这样的场景&#xff1f;凌晨两点&#xff0c;实验室服务器正在拉取一个PyTorch-CUDA镜像&#xff0c;进度条卡在30%已持续十分钟&#xff1b;反复重试后依然失…

作者头像 李华
网站建设 2026/3/22 7:57:25

MobaXterm高效运维:实战技巧全解析

MobaXterm高效运维实战技术文章大纲引言MobaXterm简介&#xff1a;功能特点、适用场景高效运维的需求背景&#xff1a;远程管理、多协议支持、自动化需求MobaXterm核心功能解析一体化终端工具&#xff1a;SSH、RDP、VNC、FTP集成会话管理&#xff1a;多标签、分组、保存与共享文…

作者头像 李华