LeetCode 热题100 3. 无重复字符子串
题目:给定一个字符串 s
,请你找出其中不含有重复字符的 最长子串 的长度。
实例:
输入:s="abcabcbb"
输出:3
解释:因为无重复字符的最长子串是“abc”,所以其长度为3
解析:采用哈希表来进行匹配,通过滑动窗口,记录滑动窗口的最大长度即可
class Solution {
public:
int lengthOfLongestSubstring(string s) {
int res=0,start=0; //用来记录滑动窗口的大小以及滑动窗口当前的起始位置
map<char,int> mp;
for(int i=0;i<s.length();++i){
if(mp.count(s[i])){ //如果mp中已经出现了当前字母,则返回1;反之返回0
start=max(start, mp[s[i]]+1); //记录新的起始位置
}
res=max(res,i-start+1); //记录滑动窗口大小
mp[s[i]]=i; //记下当前字母的位置
}
return res;
}
};
谁人畏惧现实,谁人将从梦中消失
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· 阿里巴巴 QwQ-32B真的超越了 DeepSeek R-1吗?
· 【译】Visual Studio 中新的强大生产力特性
· 10年+ .NET Coder 心语 ── 封装的思维:从隐藏、稳定开始理解其本质意义
· 【设计模式】告别冗长if-else语句:使用策略模式优化代码结构