0003. 无重复字符的最长子串

0003. 无重复字符的最长子串 #

  • 标签:滑动窗口,双指针
  • 难度:中等

一、题目说明 #

描述:给定一个字符串 s

要求:找出其中不含有重复字符的最长子串的长度。

说明

  • $0 \le s.length \le 5 * 10^4$。
  • s 由英文字母、数字、符号和空格组成。

示例

  • 示例 1:
输入: s = "abcabcbb"
输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。
  • 示例 2:
输入: s = "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。
  • 示例3:
输入: s = "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
     请注意,你的答案必须是子串的长度,"pwke" 是一个子序列,不是子串。

二、解题思路 #

1. 滑动窗口 #

public int lengthOfLongestSubstring(String s) {
    if(null==s || s.length()==0){
        return 0;
    }
    int left = 0;
    Map<Character, Integer> map = new HashMap();
    int max = 0;
    for(int right=0;right<s.length();right++){
        if(map.containsKey(s.charAt(right))){
            left = Math.max(left, map.get(s.charAt(right)) + 1);
        }
        map.put(s.charAt(right), right);
        max = Math.max(max, right - left + 1);
    }
    return max;
}