嗯,没啥好说的,直接上题!
1.leetcode-3.无重复字符的最长子串
题目描述
给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。
输入: "abcabcbb"
输出: 3
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
解题思路
定义字符到索引的映射, 当我们找到重复的字符时,我们可以立即跳过该窗口。也就是说,如果 s[i]在 [j, i)范围内有与 i'重复的字符,我们不需要逐渐增加 j 。 我们可以直接跳过 [j,i']范围内的所有元素,并将 j 变为 i' + 1.
代码
class Solution {
public:
int lengthOfLongestSubstring(string s) {
unordered_map<char, int> hashmap;
int res=0;
for(int i=0,j=0;i<s.size();i++){
j = max(hashmap[s[i]], j);
res = max(res, i-j+1);
hashmap[s[i]] = i+1;
}
return res;
}
};