news 2026/4/16 17:31:22

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/4/16 12:08:30

Git工作流规范:在PyTorch项目中实施Branch策略

Git工作流规范&#xff1a;在PyTorch项目中实施Branch策略 在现代AI团队的日常开发中&#xff0c;你是否经历过这样的场景&#xff1a;同事刚提交的代码导致整个训练流程崩溃&#xff0c;而问题原因竟是他本地装了不同版本的PyTorch&#xff1f;或者你在复现一篇论文实验时&…

作者头像 李华
网站建设 2026/4/16 13:45:34

分布式数据并行(DDP)配置:PyTorch-CUDA-v2.7多卡训练教程

分布式数据并行&#xff08;DDP&#xff09;配置&#xff1a;PyTorch-CUDA-v2.7多卡训练实战指南 在当今深度学习模型动辄数十亿参数的背景下&#xff0c;单张GPU早已无法支撑主流任务的训练需求。从大语言模型到高分辨率图像生成&#xff0c;算力瓶颈成为制约研发效率的关键因…

作者头像 李华
网站建设 2026/4/16 12:02:22

Jupyter密码设置与安全访问:PyTorch容器使用注意事项

Jupyter密码设置与安全访问&#xff1a;PyTorch容器使用注意事项 在如今的AI开发实践中&#xff0c;越来越多工程师选择在远程服务器或云平台上运行搭载 PyTorch 和 Jupyter 的 Docker 容器。这种组合极大提升了开发效率——无需繁琐配置即可快速进入模型调试环境。但随之而来的…

作者头像 李华
网站建设 2026/4/16 12:07:22

适合新手的5个爬虫工具软件,非常强大~

爬虫&#xff0c;又称为网络爬虫或网页爬虫&#xff0c;是一种自动浏览互联网的程序&#xff0c;它按照一定的算法顺序访问网页&#xff0c;并从中提取有用信息。爬虫软件通常由以下几部分组成&#xff1a; - 用户代理&#xff08;User-Agent&#xff09;&#xff1a;模拟浏览…

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

避免常见错误:PyTorch安装时CUDA不匹配问题终极解决方案

避免常见错误&#xff1a;PyTorch安装时CUDA不匹配问题终极解决方案 在深度学习项目刚启动的那一刻&#xff0c;最让人沮丧的不是模型训练慢&#xff0c;也不是数据清洗繁琐&#xff0c;而是满怀期待地运行代码后&#xff0c;终端弹出那句冰冷的提示&#xff1a; False——当…

作者头像 李华