leetcode3-无重复字符的最长子串

leetcode 3

思路

  1. 滑动窗口 :我们可以通过维护一个滑动窗口来解决这个问题。滑动窗口由两个指针(left 和 right)控制,这里right在下面代码中是i

  2. 右指针扩展窗口:右指针(i)会向右移动,直到遇到重复的字符

  3. 左指针收缩窗口:当右指针遇到重复字符时,我们需要将左指针向右移动来收缩窗口,使得窗口内的元素都是唯一的无重复子串的

  4. 使用哈希map来存储字符:可以使用一个哈希集合来记录窗口中出现的字符。当遇到重复字符时,通过更新left指针来确保去掉重复字符

  5. 更新最大长度:每次右指针扩展后,我们都计算当前窗口的大小,并更新最大长度

实现

json 复制代码
var lengthOfLongestSubstring = function (s) {
    const map = new Map();
    let max = 0, left = 0;
    for (let i = 0; i < s.length; i++) {
        if (map.has(s[i])) {
            let index = map.get(s[i])
            if (left < index + 1) {
                // 在滑动窗口区间内出现了重复的元素
                left = index + 1;
            }
        }
        map.set(s[i], i)
        max = Math.max(max, i - left + 1)
    }
    return max;
}
相关推荐
数据大魔方12 小时前
【期货量化实战】日内动量策略:顺势而为的短线交易法(Python源码)
开发语言·数据库·python·mysql·算法·github·程序员创富
POLITE312 小时前
Leetcode 23. 合并 K 个升序链表 (Day 12)
算法·leetcode·链表
楚来客13 小时前
AI基础概念之八:Transformer算法通俗解析
人工智能·算法·transformer
XTTX11013 小时前
Vue3+Cesium教程(36)--动态设置降雨效果
前端·javascript·vue.js
Echo_NGC223713 小时前
【神经视频编解码NVC】传统神经视频编解码完全指南:从零读懂 AI 视频压缩的基石
人工智能·深度学习·算法·机器学习·视频编解码
会员果汁13 小时前
leetcode-动态规划-买卖股票
算法·leetcode·动态规划
橘颂TA14 小时前
【剑斩OFFER】算法的暴力美学——二进制求和
算法·leetcode·哈希算法·散列表·结构与算法
han_15 小时前
从一道前端面试题,谈 JS 对象存储特点和运算符执行顺序
前端·javascript·面试
地平线开发者15 小时前
征程 6 | cgroup sample
算法·自动驾驶