给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度
cpp
输入: s = "abcabcbb"
输出: 3
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
转载: C++常用语法------unordered_set
题目主要思想:滑动窗口
一个队列"abcabcbb",进入这个队列为"abc"满足题意,当再进入"a",队列就变成了"abca",不满足题意,所以我们需要移动队列左边的元素,直到满足题意即可
cpp
class Solution {
public:
int lengthOfLongestSubstring(string s) {
set<char> repeat;
int len=s.size();
int rp=-1,count=0;
for(int i=0;i<len;i++){
if(i!=0)
//删除a,继续往后加
repeat.erase(s[i-1]);
//无重复字符abc
while(rp+1<len&&!repeat.count(s[rp+1])){
repeat.insert(s[rp+1]);
rp++;
}
//比较最大
count=max(count,rp-i+1);
}
return count;
}
};