字符串高频算法:无重复字符的最长子串

题目

3. 无重复字符的最长子串 - 力扣(LeetCode)

解题思路

思路

方法: 滑动窗口

[!简单思路]
[^1]以示例一中的字符串 abcabcbb 为例,找出==从每一个字符开始的,不包含重复字符的最长子串==,其中最长的那个字符串即为答案。

对于示例一中的字符串,我们列举出这些结果,其中括号中表示选中的字符以及最长的字符串:

以 (a)bcabcbb 开始的最长字符串为 (abc)abcbb;
以 a(b)cabcbb 开始的最长字符串为 a(bca)bcbb;

[!为什么可以使用滑动窗口]
依次递增地枚举子串的起始位置,那么子串的结束位置也是递增的!这里的原因在于,假设我们选择字符串中的第 k 个字符作为起始位置,并且得到了不包含重复字符的最长子串的结束位置为 r
k​。那么当我们选择第 k+1 个字符作为起始位置时,首先从 k+1 到 r
k的字符显然是不重复的,并且由于少了原本的第 k 个字符,我们可以尝试继续增大 r
k,直到右侧出现了重复字符为止。
这样一来,我们就可以使用「滑动窗口」来解决这个问题了:

具体实现

分析Set方法在最长无重复子串问题中的应用

在本题中,使用了哈希集合的

  1. has(value)
- 用于检查集合中是否存在某个字符。在代码中,`occ.has(s.charAt(rk + 1))`用于判断当前字符是否已经存在于集合中。
  1. add(value)

    • 用于将一个字符添加到集合中。在代码中,occ.add(s.charAt(rk + 1))用于将新遇到的字符添加到集合中。
  2. delete(value)

    • 用于从集合中删除某个字符。在代码中,occ.delete(s.charAt(i - 1))用于在窗口左指针向右移动时,删除窗口左边界的字符。
  • 滑动窗口法

    • 使用双指针(irk)来维护一个滑动窗口,确保窗口内的字符都是不重复的。

    • i 表示窗口的左边界,rk 表示窗口的右边界。

  • Set的使用

    • occ 是一个Set,用于存储当前窗口中的字符。

    • 在外层循环中,每次左指针i移动时,会删除前一个左边界字符。

    • 内层循环中,右指针rk不断向右移动,直到遇到重复字符为止。

AC代码

var lengthOfLongestSubstring = function(s) {const occ = new Set(); // 创建哈希集合, 用户判断字符串是否重复const n = s.length; // 记录下s字符串的长度// 初始化右指针为 rk = -1, 表示右指针初始状态在字符串左边缘的左侧, 这样比较合理let rk = -1, ans = 0; // ans用来记录最终最大字符串的长度for(let i = 0; i < s.length; i++) {// 左指针向右移动一格, 移除一个字符if(i != 0) {occ.delete(s.charAt(i - 1));}// 右指针不越界并且右指针不是重复字符时while (rk + 1 < n && !occ.has(s.charAt(rk + 1))) {occ.add(s.charAt(rk + 1));++rk;}ans = Math.max(ans, rk - i + 1)}return ans;}
  • rk - i + 1

    • 当前窗口的长度是右指针 rk 减去左指针 i 加 1。这是因为索引是从 0 开始的,比如从索引 irk 的字符总共有 rk - i + 1 个。
  • Math.max(ans, rk - i + 1)

    • ans 保存的是当前找到的最长无重复子串的长度。

    • Math.max 会比较 ans 和当前窗口的长度,取较大的值作为新的 ans,确保 ans 始终记录最长的窗口长度。

判断重复字符

使用哪种数据结构来判断 是否有重复的字符?
——JavaScript 中的 Set
在 JavaScript 中,要判断字符串中是否包含重复字符,可以使用 Set 数据结构。Set 是一种特殊的数据结构,它存入的值都是唯一的,不会有重复。

[!Set 判断字符串中是否有重复字符的步骤]

步骤:

1 将字符串转为字符数组
(将字符串拆分为单个字符组成的数组,以便逐个检查字符)
2 使用 Set 存储字符:
将字符数组中的每个字符存入 Set 中
3 比较 Set 的大小和原字符串的长度
如果 Set 的大小和原字符串的长度不同,说明存在重复字符,因为 Set 会自动去重.

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/bicheng/70554.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

编译加速工具ccache

1、什么是ccache ccache&#xff08;Compilation Cache&#xff09;是一个开源的编译缓存工具&#xff0c;最初为 C/C 设计&#xff0c;但也可以用于其他语言的编译过程&#xff08;如 Objective-C、CUDA 等&#xff09;。它的核心思想是通过缓存编译结果&#xff0c;避免重复…

用Python的模式匹配(Pattern Matching)重构复杂条件逻辑:超越if-else的艺术

在Python 3.10发布两年后&#xff0c;模式匹配&#xff08;Pattern Matching&#xff09;仍然是许多开发者未曾探索的秘境。这个被误解为"加强版switch语句"的功能&#xff0c;实则是重构复杂条件逻辑的终极武器。本文将带您深入模式匹配的进阶应用&#xff0c;揭示其…

运用Deek Seeker协助数据分析

我的数据源有两张表&#xff0c;一个是每日销售表(字段有日期、产品名称、实际销量)&#xff0c;一个是每月目标表(字段有年度月份、产品名称、目标销量);我的需求是&#xff0c;按月、按年来统计每个产品的目标完成情况请问用PowerBl进行分析&#xff0c;应该如何建立数据模型…

Sentinel——Spring Boot 应用接入 Sentinel 后内存开销增长计算方式

接入 Sentinel 对 Spring Boot 应用的内存消耗影响主要取决于 规则数量、资源数量、监控粒度、并发量 等因素。 1. 核心内存消耗来源 (1) Sentinel 核心库 默认依赖&#xff1a;Sentinel Core 本身占用较小&#xff0c;通常在 10~50MB&#xff08;取决于资源数量和规则复杂度…

【设计模式】【行为型模式】策略模式(Strategy)

&#x1f44b;hi&#xff0c;我不是一名外包公司的员工&#xff0c;也不会偷吃茶水间的零食&#xff0c;我的梦想是能写高端CRUD &#x1f525; 2025本人正在沉淀中… 博客更新速度 &#x1f4eb; 欢迎V&#xff1a; flzjcsg2&#xff0c;我们共同讨论Java深渊的奥秘 &#x1f…

【高级架构师】多线程和高并发编程(三):锁(中)深入ReentrantLock

文章目录 3、深入ReentrantLock3.1 ReentrantLock和synchronized的区别3.2 AQS概述3.3 加锁流程源码剖析3.3.1 加锁流程概述3.3.2 三种加锁源码分析3.3.2.1 lock方法3.3.2.2 tryLock方法3.3.2.3 lockInterruptibly方法 3.4 释放锁流程源码剖析3.4.1 释放锁流程概述3.4.2 释放锁…

WPF 进度条(ProgressBar)示例一

本文讲述&#xff1a;WPF 进度条(ProgressBar)简单的样式修改和使用。 进度显示界面&#xff1a;使用UserControl把ProgressBar和进度值以及要显示的内容全部组装在UserControl界面中&#xff0c;方便其他界面直接进行使用。 <UserControl x:Class"DefProcessBarDemo…

Android studio怎么创建assets目录

在Android Studio中创建assets文件夹是一个简单的步骤&#xff0c;通常用于存储不需要编译的资源文件&#xff0c;如文本文件、图片、音频等 main文件夹&#xff0c;邮件new->folder-assets folder

工业相机在工业生产制造过程中的视觉检测技术应用

随着技术不断发展以及工业4.0时代的到来&#xff0c;利用工业相机进行视觉检测技术已经成为制造业不可或缺的一部分。通过结合先进的计算机视觉、AI算法和自动化设备&#xff0c;工业视觉检测为生产线质量控制和效率提升提供了革命性的解决方案。 一、什么是工业视觉检测技术 …

vscode中使用code-runner插件运行c程序语法报错code: 1

代码 int main() {// 定义变量a&#xff0c;赋值为10int a 10;// 定义变量b&#xff0c;赋值为20int b 20;// 定义变量c&#xff0c;将a和b相加的结果赋值给cint c a b;// 输出c的值printf("%d", c);// 返回0&#xff0c;表示程序正常结束return 0; }问题&#…

快速上手Vim的使用

Vim Linux编辑器-vim使用命令行模式下所有选项都可以带数字底行模式可视块模式&#xff08;ctrlV进入&#xff09; Linux编辑器-vim使用 Vim有多种模式的编辑器。能帮助我们很快的进行代码的编辑&#xff0c;甚至完成很多其他事情。 默认情况下我们打开vim在命令模式下&#x…

3. 学习UVM的核心组件

文章目录 前言一、UVM 核心组件详解1. uvm_component2. uvm_object3. uvm_driver4. uvm_monitor5. uvm_agent6. uvm_sequencer7. uvm_sequence8. uvm_sequence_item9. uvm_scoreboard10. uvm_env11. uvm_test 二、相互关系三、综合示例 前言 UVM&#xff08;Universal Verific…

k8s中,一.service发布服务,二.dashboard:基于网页的k8s管理插件,三.资源服务与帐号权限

一.service资源对内发布服务Cluster IP对外发布服务NodePortIngress 二.dashboard:基于网页的k8s管理插件 三.资源服务与帐号权限一.service:用户无法预知pod的ip地址以及所在的节点,多个相同的pod如何访问他们上面的服务功能:1.服务自动感知:pod迁移后访问service的ip,不受影响…

MySQL——表操作及查询

一.表操作 MySQL的操作中&#xff0c;一些专用的词无论是大写还是小写都是可以通过的。 1.插入数据 INSERT [INTO] table_name (列名称…)VALUES (列数据…), (列数据…); "[]"表示可有可无&#xff0c;插入时&#xff0c;如果不指定要插入的列&#xff0c;则表示默…

数据结构-基础

1、概念&#xff1a; 程序 数据结构 算法 2、程序的好坏 可读性&#xff0c;稳定性&#xff0c;扩展性&#xff0c;时间复杂度&#xff0c;空间复杂度。 3、数据结构 是指存储、组织数据的方式&#xff0c;以便高效地进行访问和修改。通过选择适当的数据结构&#xff0c; 能…

本地部署DeepSeek(Mac版本,带图形化操作界面)

一、下载安装&#xff1a;Ollama 官网下载&#xff1a;Download Ollama on macOS 二、安装Ollama 1、直接解压zip压缩包&#xff0c;解压出来就是应用程序 2、直接将Ollama拖到应用程序中即可 3、启动终端命令验证 # 输入 ollama 代表已经安装成功。 4、下载模型 点击模型…

Nginx配置 ngx_http_proxy_connect_module 模块及安装

1、配置完互联网yum源后,安装相关依赖软件包 [root@server soft]# yum install -y patch pcre pcre-devel make gcc gcc-c++ openssl openssh [root@server soft]# yum install openssl* 2、解压缩软件,加载模块 [root@server soft]# ls nginx-1.20.2 nginx-1.20.2.tar.gz …

宾馆民宿酒店住宿管理系统+小程序项目需求分析文档

该系统是一款专为现代酒店设计的高效、智能、易用的管理工具,旨在帮助酒店提升运营效率、优化客户体验,提升客户满意度与忠诚度,并促进业务增长。系统采用先进的云计算技术,支持小程序等多平台访问,第三方接口,确保数据安全与稳定。本系统主要针对中小型精品酒店、连锁酒…

山东大学软件学院人机交互期末复习笔记

文章目录 2022-2023 数媒方向2023-2024 软工方向重点题目绪论发展阶段 感知和认知基础视觉听觉肤觉知觉认知过程和交互设计原则感知和识别注意记忆问题解决语言处理影响认知的因素 立体显示技术及其应用红蓝眼镜偏振式眼镜主动式&#xff08;快门时&#xff09;立体眼镜 交互设…

《Kettle实操案例一(全量/增量更新与邮件发送)》

目录 一、场景描述:二、要求:三、思路四、整体作业五、各部分详细配置1、Start2、转换-获取执行开始时间3、获取目标表抽取前行数4、检验字段的值5、增量更新6、全量更新7、获取目标表抽取后行数8、获取执行结束时间9、日志写入数据库10、写日志11、发送数据抽取完成邮件 六、最…