天天看点

LeetCode题解 —— 3. 无重复字符的最长子串

题目描述

给定一个字符串,请你找出其中不含有重复字符的 最长子串 的长度。

示例 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;
    }
};