当前位置: 首页 > news >正文

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

leetcode 3
在这里插入图片描述

思路

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

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

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

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

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

实现

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;
}

相关文章:

  • (1-6-1)Java 集合
  • JavaWeb:SpringBootAOP切面实现统计方法耗时和源码解析
  • Linux相关概念和易错知识点(41)(UDP、TCP报头结构)
  • uniapp中懒加载图片组件的封装与应用
  • 【前端设计模式讲解】工厂模式
  • Java高频面试之并发编程-20
  • Ethan的日记5/25
  • python打卡day36
  • 十二、【鸿蒙 NEXT】如何使用系统api实现视频压缩
  • uni-app学习笔记十一--vu3 watch和watchEffect侦听
  • Lua 脚本在 Redis 中的运用-23(Lua 脚本语法教程)
  • 考虑安全稳定约束的优化调度综述
  • 基于Python Anaconda环境,使用CNN-LSTM模型预测碳交易价格的完整技术方案
  • removeIf() 方法,结合 Lambda 表达式
  • Linux初始-历史(1)
  • Linux操作系统 使用信号量实现进程同步
  • OpenCV 第7课 图像处理之平滑(一)
  • 基于CEEMDAN-Transformer-BiLSTM的多特征风速气候预测的完整实现方案及PyTorch源码解析
  • Reactor模式详解:高并发场景下的事件驱动架构
  • 【redis】redis和hiredis的基本使用
  • 网站建设中html下载/中国新闻
  • 网站建设任务书/百度seo排名培训 优化
  • 购物网站难做/百度开放平台
  • 惠州自适应网站建设/国内前10电商代运营公司
  • 江西建设职业技术学院最新官方网站/黑帽seo排名技术
  • 昌吉做网站需要多少钱/上海网络推广公司