Skip to content

无重复字符的最长子串 #6

Open
@Bulandent

Description

@Bulandent

难度:中等
来源:3. 无重复字符的最长子串

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

示例 1:

输入: s = "abcabcbb"
输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。

示例 2:

输入: s = "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。

示例 3:

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

示例 4:

输入: s = ""
输出: 0

提示:

0 <= s.length <= 5 * 104
s 由英文字母、数字、符号和空格组成

思路:

  • 与其用变量来存储无重复的最长子串,还不如用 max 来存储最长子串的长度,这样内存占用会更小;
  • 最长子串其实就可以看成滑动窗口,子串的左下标 i 就是窗口的左侧位置,子串的右下标 j 就是窗口的右侧位置;
  • 当遍历字符串的时候,就可以通过左坐标 i 来控制窗口左侧位置的移动,而遍历的索引 j 就是右窗口位置;
  • 通过左坐标 i 和遍历索引 j 两个数据即可得到子串,然后将子串和当前字符进行匹配,如果子串包含当前字符则更新左坐标 i,否则更新子串最大长度 max;

题解:滑动窗口

/**
 * @param {string} s
 * @return {number}
 */
var lengthOfLongestSubstring = function(s) {
    let max = 0, // 最大长度
        i = 0, // 左下标
        index = 0; // 
    for (let j = 0, l = s.length; j < l; j++) {
        index = s.slice(i, j).indexOf(s[j])
        if (index === -1) {
            max = Math.max(max, j - i + 1)
        } else {
            i += index + 1
        }
    }
    return max
};

Metadata

Metadata

Assignees

No one assigned

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions