题目:给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。
示例 :
输入: “abcabcbb”
输出: 3
解释: 因为无重复字符的最长子串是 “abc”,所以其长度为 3。
C++
1.滑动窗口(双指针法)+hash
一开始联想到kmp,然后发现实际还是双指针法的运用,最后看题解这也叫滑动窗口,确实和计网中的滑动窗口挺像
思路是从开始记录两个指针,第一个指针表示从它开始的最长子串长度,第二个通过移动对比前面是否出现过该字符来记录最长长度(利用hash思想),len=后-前+1;
其实题目也可以开hash数组(应该更快),这里熟悉一下set,用unordered_set来做映射
时间复杂度O(n),空间O(1)
class Solution {
public:
int lengthOfLongestSubstring(string s) {
unordered_set<char> hash;
int n=s.length();
if(n<2)return n;
int k=0,ans=1;
for(int i=0;i<n;i++){
while(k<n&&!hash.count(s[k])){
hash.insert(s[k]);
ans=max(ans,k-i+1);
k++;
}
hash.erase(s[i]);
if(n-i<ans)break;//剪枝
}
return ans;
}
};
Python
class Solution:
def lengthOfLongestSubstring(self, s: str) -> int:
ans=0
left=0
right=0
hashset=set([])
n=len(s)
while left<n:
while right<n and s[right] not in hashset:
hashset.add(s[right])
ans=max(ans,right-left+1)
right+=1
hashset.remove(s[left])
left+=1
if n-left <ans:
break
return ans
java
class Solution {
public int lengthOfLongestSubstring(String s) {
Set<Character> hashset=new HashSet<Character>();
int ans=0,k=0;
int n=s.length();
for(int i=0;i<n;i++){
while(k<n && hashset.contains(s.charAt(k))==false){
hashset.add(s.charAt(k));
ans=Math.max(ans,k-i+1);
k++;
}
hashset.remove(s.charAt(i));
}
return ans;
}
}