news 2026/4/3 1:28:44

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/29 0:51:56

揭秘ChatGPT与AI Agent的本质区别:从只会聊天到自主执行任务的超级进化,开发者必藏!

本文详解AI Agent与传统LLM的本质区别&#xff0c;揭示其通过工具调用、记忆和反应性实现自主任务执行的核心机制。解析ReAct循环工作原理、不同类型分类及现代系统架构&#xff0c;展示从简单反射到多Agent协作的进化路径。掌握这些技术&#xff0c;开发者可构建从个人助理到复…

作者头像 李华
网站建设 2026/3/13 5:46:39

清华TUNA镜像站加速PyTorch-CUDA-v2.7下载实测

清华TUNA镜像站加速PyTorch-CUDA-v2.7下载实测 在深度学习项目启动的前夜&#xff0c;最让人焦虑的往往不是模型结构设计或数据清洗——而是当你敲下 pip install torch 后&#xff0c;终端里那龟速爬行的进度条&#xff0c;甚至几度中断重连。这种“卡在起跑线”的窘境&#…

作者头像 李华
网站建设 2026/3/30 23:40:17

RTX4090深度学习实测:PyTorch-CUDA-v2.7镜像性能表现

RTX4090深度学习实测&#xff1a;PyTorch-CUDA-v2.7镜像性能表现 在当今AI模型规模不断膨胀的背景下&#xff0c;一块能“扛得住训练”的消费级显卡&#xff0c;几乎成了每个深度学习工程师梦寐以求的工作伙伴。而当NVIDIA推出RTX 4090时&#xff0c;整个社区都为之振奋——这不…

作者头像 李华
网站建设 2026/3/29 11:37:40

告别复杂依赖!PyTorch-CUDA-v2.7镜像让模型训练即刻开始

告别复杂依赖&#xff01;PyTorch-CUDA-v2.7镜像让模型训练即刻开始 在深度学习项目启动的那一刻&#xff0c;你是否曾经历过这样的场景&#xff1a;满怀热情地打开新电脑&#xff0c;准备复现一篇论文或训练一个图像分类模型&#xff0c;结果却卡在了环境配置上&#xff1f;to…

作者头像 李华
网站建设 2026/3/28 18:50:14

主流SRM系统推荐:哪款最适合您的行业?

在当今竞争激烈的市场环境中&#xff0c;供应链的效率和韧性已成为企业生存和发展的命脉。供应商关系管理&#xff08;SRM&#xff09;系统作为连接企业与供应商的核心枢纽&#xff0c;其重要性不言而喻。然而&#xff0c;面对市场上众多的SRM软件&#xff0c;从功能丰富的平台…

作者头像 李华
网站建设 2026/3/30 13:38:40

小白也能学会:图形化界面操作PyTorch-CUDA深度学习环境

小白也能学会&#xff1a;图形化界面操作PyTorch-CUDA深度学习环境 在人工智能浪潮席卷各行各业的今天&#xff0c;越来越多的人希望迈入深度学习的大门。但现实往往令人望而却步——安装 PyTorch、配置 CUDA、处理版本冲突……一连串术语和报错信息足以让初学者止步不前。 有没…

作者头像 李华