【算法】无重复字符的最长子串

难度:中等

题目

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

示例:

示例1:

输入:s = "abcabcbb"

输出:3

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

示例2:

输入:s = "pwwkew"

输出:3

解释:因为无重复字符的最长子串是 "wke",所以其长度为 3。

请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。

提示:

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

解题思路:

这道题目的核心在于使用滑动窗口的思想来遍历字符串,寻找不含重复字符的最长子串。滑动窗口是一种处理数组/字符串区间问题的有效方法,它可以在遍历过程中动态调整待考察的子序列(窗口)。

  1. 初始化:定义两个指针left和right,分别表示当前窗口的左右边界,初始时都指向字符串的起始位置。同时,用一个哈希表(在JavaScript中可以使用对象或Map)来记录窗口内每个字符出现的最新位置,以方便快速判断字符是否重复。
  2. 扩大窗口:将右指针right逐步向右移动,每次移动都将right指向的字符加入哈希表,并更新该字符的最新位置。如果加入字符后没有造成重复(即新加入的字符的最新位置大于等于left),则说明窗口内的字符都是唯一的,此时可以更新最长子串长度。
  3. 缩小窗口:当加入字符导致重复时,就需要移动左指针left来缩小窗口,直到窗口内的字符再次变得唯一。在移动left的过程中,需要从哈希表中删除left指向的字符,因为这个字符已经不再属于窗口。
  4. 循环进行:重复步骤2和3,直到右指针达到字符串末尾。
  5. 返回结果:循环结束后,最长子串的长度即为所求。
javascript 复制代码
/**
 * @param {string} s
 * @return {number}
 */

var lengthOfLongestSubstring = function (s) {
    let left = 0;
    let maxLength = 0;
    let charMap = new Map(); // 用于记录字符及其在字符串中的位置

    for (let right = 0; right < s.length; right++) {
        let currentChar = s[right];

        // 如果当前字符已经在窗口中存在,则需要更新左边界
        if (charMap.has(currentChar)) {
            left = Math.max(charMap.get(currentChar) + 1, left);
        }

        // 更新字符的最新位置
        charMap.set(currentChar, right);

        // 计算当前窗口的长度
        maxLength = Math.max(maxLength, right - left + 1);
    }

    return maxLength;
};

这段代码实现了上述的滑动窗口算法,通过不断调整窗口大小来寻找最长的无重复字符子串,并最终返回该子串的长度。

相关推荐
WolfGang00732123 分钟前
代码随想录算法训练营Day28 | 509.斐波那契数列、70.爬楼梯、746.使用最小花费爬楼梯
算法
Boop_wu27 分钟前
[Java EE] 多线程进阶(JUC)(2)
java·jvm·算法
闻缺陷则喜何志丹1 小时前
【SOSDP模板 容斥原理 逆向思考】3757. 有效子序列的数量|分数未知
c++·算法·力扣·容斥原理·sosdp·逆向思考
CoovallyAIHub1 小时前
如何在手机上轻松识别多种鸟类?我们发现了更简单的秘密……
深度学习·算法·计算机视觉
第二只羽毛1 小时前
遵守robots协议的友好爬虫
大数据·爬虫·python·算法·网络爬虫
艾斯比的日常2 小时前
Java 三色标记算法:并发垃圾回收的核心技术解析
java·开发语言·算法
CoovallyAIHub2 小时前
抛弃LLM!MIT用纯视觉方法破解ARC难题,性能接近人类水平
深度学习·算法·计算机视觉
程序猿编码2 小时前
PRINCE算法的密码生成器:原理与设计思路(C/C++代码实现)
c语言·网络·c++·算法·安全·prince
高洁012 小时前
具身智能-视觉语言导航(VLN)
深度学习·算法·aigc·transformer·知识图谱
Croa-vo2 小时前
TikTok 数据工程师三轮 VO 超详细面经:技术深挖 + 建模推导 + 压力测试全记录
javascript·数据结构·经验分享·算法·面试