题目描述
给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。
示例 1:
输入: "abcabcbb"
输出: 3
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
示例 2:
输入: "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。
示例 3:
输入: "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。
解题思路
维护一个<char, index>
的 hashmap 来存储字符和对应的下标,采用滑动窗口双指针的思想,一个指针 start 用来维护最长不重复子串的左边界,另一个指针 i 用来遍历字符串及充当右边界,同时更新 s[i] 在 hashmap 中的值。如果 s[i] 已经在 hashmap 中,且s[i]的hash值大于等于start,即 s[i] 在之前维护的最长不重复子串内,则维护左指针到hash[s[i]] + 1 。
因为都是字符,所以可以考虑用数组来代替hashmap。
解题代码
class Solution {
public:
int lengthOfLongestSubstring(string s) {
vector<int> hash(256, -1);
int res = 0;
int start = 0;
//[start...i]
for(int i = 0; i < s.size(); i++){
if(hash[s[i]] >= start)
start = hash[s[i]] + 1;
hash[s[i]] = i;
res = max(res, i - start + 1);
}
return res;
}
};