题目描述:
给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度。
示例 1:
输入: s = "abcabcbb"
输出: 3
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
示例 2:输入: s = "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。
示例 3:输入: s = "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。
class Solution {
public:
int lengthOfLongestSubstring(string s) {
//创建一个数组存放字符的下标
vector<int> pos(128,-1);
int ans = 0;
for(int i = 0,j = 0; i < s.length(); i++){
//更新左边界
j = max(j, pos[s[i]] + 1);
//更新子串长度
ans = max(ans, i - j + 1);
pos[s[i]] = i;
}
return ans;
}
};
创建一个数组用来存储字符的下标,ans用来存储最长子串的长度。i 表示子串的右边界,j表示子串的左边界
第一次循环:
i = 0,j = 0; 更新左边界 j = max(0,0) 更新子串长度 ans = max(0,1)
然后将pos\['a'\] = 0;
第二次循环:
i = 1,j = 0; 更新左边界 j = max(0,0) 更新子串长度 ans = max(1,2)
然后将pos\['b'\] = 1;
第三次循环:
i = 2,j = 0; 更新左边界 j = max(0,0) 更新子串长度 ans = max(2,3)
然后将pos\['c'\] = 2;
第四次循环:
i = 3,j = 0; 更新左边界 j = max(0,0) 更新子串长度 ans = max(3,4)
然后将pos\['d'\] = 3;
第五次循环:
i = 4,j = 0; 更新左边界 j = max(0,2) 更新子串长度 ans = max(4,3)
然后将pos\['b'\] = 4;
第六次循环:
i = 5,j = 0; 更新左边界 j = max(2,1) 更新子串长度 ans = max(4,4)
然后将pos\['a'\] = 5;
第七次循环:
i = 6,j = 0; 更新左边界 j = max(2,0) 更新子串长度 ans = max(4,5)
然后将pos\['e'\] = 6;
第八次循环:
i = 7,j = 0; 更新左边界 j = max(2,3) 更新子串长度 ans = max(5,5)
然后将pos\['c'\] = 7;
故循环结束后ans = 5