news 2026/3/7 17:07:55

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/4 3:48:53

深度解析大模型微调技术:LoRA、QLoRA、DPO全对比,建议收藏!

深度解析2025年大模型微调技术&#xff1a;LoRA、QLoRA、DPO全对比&#xff0c;建议收藏&#xff01; 文章系统介绍了大语言模型微调技术的演进与现状&#xff0c;重点分析了参数高效微调(PEFT)的革命性技术&#xff0c;包括LoRA及其改进版QLoRA、VeRA、DoRA和AdaLoRA&#xff…

作者头像 李华
网站建设 2026/3/5 3:49:11

为什么越来越多开发者选择PyTorch-CUDA预装镜像?

为什么越来越多开发者选择PyTorch-CUDA预装镜像&#xff1f; 在深度学习项目启动的前48小时里&#xff0c;你更愿意把时间花在模型设计上&#xff0c;还是反复折腾CUDA版本和驱动兼容性&#xff1f;这几乎是每个AI工程师都经历过的灵魂拷问。而如今&#xff0c;越来越多团队正在…

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

GPU算力租赁新趋势:结合PyTorch镜像实现按需付费模式

GPU算力租赁新趋势&#xff1a;结合PyTorch镜像实现按需付费模式 在AI模型越来越“大”、训练任务越来越复杂的今天&#xff0c;一个开发者最怕听到的提示是什么&#xff1f; 不是“代码有bug”&#xff0c;而是——“CUDA out of memory”。 这句报错背后&#xff0c;往往意味…

作者头像 李华
网站建设 2026/2/7 19:39:05

AI Agent与RAG技术:开发者进阶的核心竞争力

今年&#xff0c;AI 技术栈的迭代速度&#xff0c;已经超过了大多数程序员的学习速度。 当你的同事还在讨论如何写 Prompt 时&#xff0c;DeepSeek R1、Gemini 3 等新一代推理模型&#xff0c;已经重新定义了人机交互的边界。当你的团队还在为 RAG 的准确率头疼时&#xff0c;L…

作者头像 李华
网站建设 2026/3/7 13:34:23

开源大模型训练利器:PyTorch-CUDA-v2.7镜像深度评测

开源大模型训练利器&#xff1a;PyTorch-CUDA-v2.7镜像深度评测 在当今AI研发节奏日益加快的背景下&#xff0c;一个稳定、高效且开箱即用的深度学习环境&#xff0c;已经成为决定项目成败的关键因素。想象一下&#xff1a;你刚刚接手一个前沿的大模型训练任务&#xff0c;GPU服…

作者头像 李华
网站建设 2026/2/24 17:53:44

JupyterLab集成PyTorch环境:通过容器化镜像一键启动

JupyterLab集成PyTorch环境&#xff1a;通过容器化镜像一键启动 在深度学习项目中&#xff0c;你是否曾经历过这样的场景&#xff1a;代码在本地跑得好好的&#xff0c;换一台机器却报出一连串依赖错误&#xff1f;或者好不容易装好 PyTorch&#xff0c;却发现 torch.cuda.is_…

作者头像 李华