滑动窗口

嗯,没啥好说的,直接上题!

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;
    }
};
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容