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;
}
相关推荐
前端与小赵2 分钟前
vue3中 ref() 和 reactive() 的区别
前端·javascript·vue.js
先做个垃圾出来………10 分钟前
差分数组(Difference Array)
java·数据结构·算法
魔云连洲17 分钟前
Vue的响应式底层原理:Proxy vs defineProperty
前端·javascript·vue.js
hansang_IR33 分钟前
【题解】洛谷 P4286 [SHOI2008] 安全的航线 [递归分治]
c++·数学·算法·dfs·题解·向量·点积
乐迪信息33 分钟前
乐迪信息:AI摄像机在智慧煤矿人员安全与行为识别中的技术应用
大数据·人工智能·算法·安全·视觉检测
Hilaku33 分钟前
深入URL和URLSearchParams:别再用正则表达式去折磨URL了
前端·javascript·代码规范
weixin_4569042739 分钟前
Vue.jsmain.js/request.js/user.js/store/index.js Vuex状态管理项目核心模块深度解析
前端·javascript·vue.js
伍哥的传说42 分钟前
Vue 3.6 Alien Signals:让响应式性能飞跃式提升
前端·javascript·vue.js·vue性能优化·alien-signals·细粒度更新·vue 3.6新特性
多恩Stone1 小时前
【3DV 进阶-2】Hunyuan3D2.1 训练代码详细理解下-数据读取流程
人工智能·python·算法·3d·aigc
dragoooon341 小时前
[数据结构——lesson5.1链表的应用]
数据结构·链表