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;
}
相关推荐
丙寅21 小时前
微信小程序反编译遇到 TypeError: _typeof3 is not a function
开发语言·javascript·ecmascript
青衫码上行21 小时前
【Java Web学习 | 第十篇】JavaScript(4) 对象
java·开发语言·前端·javascript·学习
.柒宇.21 小时前
力扣hoT100之找到字符串中所有字母异位词(java版)
java·数据结构·算法·leetcode
silence_xiang1 天前
【React】首页悬浮球实现,点击出现悬浮框
前端·javascript·react.js
松岛雾奈.2301 天前
机器学习--KNN算法中的距离、范数、正则化
人工智能·算法·机器学习
兮山与1 天前
算法33.0
算法
隔壁的大叔1 天前
由于vite版本不一致,导致vue组件引入报错
javascript·vue.js
Brduino脑机接口技术答疑1 天前
支持向量机(SVM)在脑电情绪识别中的学术解析与研究进展
人工智能·算法·机器学习·支持向量机·数据分析
超级罗伯特1 天前
大屏自适应,响应式布局,亲测有效
前端·javascript·html·大屏·驾驶舱
青衫码上行1 天前
【Java Web学习 | 第九篇】JavaScript(3) 数组+函数
java·开发语言·前端·javascript·学习