1.题目:
给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。
2.示例:
示例 1:
输入: “abcabcbb”
输出: 3
解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。
示例 2:
输入: “bbbbb”
输出: 1
解释: 因为无重复字符的最长子串是 “b”,所以其长度为 1。
示例 3:
输入: “pwwkew”
输出: 3
解释: 因为无重复字符的最长子串是 “wke”,所以其长度为 3。
请注意,你的答案必须是 子串 的长度,“pwke” 是一个子序列,不是子串。
3.思路:
可以利用一个滑动窗口,当有重复时,删除掉重复的字符(向前滑动),可利用一个数组或哈希表来实现。
4.代码:
a.数组实现:
int lengthOfLongestSubstring(string s) {
int m[256]={0}; //字符ascii表示为八位,0~255,下表为对应字符的ascii
int res=0,left=0;
for(int i=0;i<s.length();i++){ //遍历字符串
if(m[s[i]]==0||m[s[i]]<left) //left->i 未出现重复,m[s[i]]==0表示未出现s[i],m[s[i]]<left表示出现过s[i]但不在left->i区间内。
res=max(res,i-left+1);
else //出现重复
left=m[s[i]];
m[s[i]]=i+1; //left下次更新位置
}
return res;
}
2.哈希表实现
int lengthOfLongestSubstring(string s) {
int res=0,left=0;
unordered_map<char,int> m;
for(int i=0;i<s.length();i++){
left=max(left,m[s[i]]);
m[s[i]]=i+1;
res=max(res,i-left+1);
}
return res;
}