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

leetcode 3 无重复字符的最长子串

一、问题描述

二、解题思路

整体思路:

只需要比较以每个位置为首的最长无重复子串的长度就可以得到整体最长无重复子串的长度,模拟这个过程,我们发现可以用双指针法来解决。

经过观察我们可以发现以下两个规律:

(1)固定窗口的左端时,在进窗口的过程中如果发现与前面的字符重复,则无需再进窗口;

若字符串为“abcabcbb”,left指向第一个a(已标红),在进窗口的过程中遇到第一个与前面重复的字符a(已标红),则无需再进窗口,以当前left为首的最长无重复字符的子串的长度为3.

(2)出窗口时,right无需回退到left+1的位置,left需要前进到与s[right]重复的字符的后一个位置即可。

若字符串为“abcabcbb”,left指向第一个a(已标红),right指向i=字符a(已标红),当left++后,right无需回退到left+1的位置,只需要保持不变,等待left++,再进行后续操作,因为“bca”是无重复字符的。

详细思路:

(1)定义left,right来维护窗口,数组hash用来记录字符在当前窗口中出现的次数,初始化为0,length用于记录无重复字符的子串的长度;

(2)滑动窗口算法流程:

<1>进窗口 

hash[s[right]]++;

<2>判断+出窗口

while(hash[s[right]]>1&&left<=right)

                hash[s[left++]]--;

<3>更新长度

length=max(length,right-left+1);

三、代码实现

时间复杂度:T(n)=O(n)

虽然有两重while循环,但是每个元素进窗口一次,出窗口一次,时间复杂度为2n

空间复杂度:S(n)=O(1)

class Solution {
public:int lengthOfLongestSubstring(string s) {//滑动窗口int left=0,right=0,n=s.size();int hash[128]={0};int length=0;while(right!=n){//进窗口hash[s[right]]++;//判断while(hash[s[right]]>1&&left<=right)hash[s[left++]]--;//更新length=max(length,right-left+1);right++;}return length;}
};

http://www.dtcms.com/a/341583.html

相关文章:

  • 个人使用AI开发的《PlSqlRewrite4GaussDB(PLSQL自动转换工具)1.0.1 BETA》发布
  • 【OneAI】使用Rust构建的轻量AI网关
  • linux环境问题
  • HyperMesh许可证分配优化策略
  • 【Ansible】变量、机密、事实
  • 福昕PDF编辑软件高级版下载与详细图文安装教程!!
  • Pub/Sub是什么意思
  • LWIP的Socket API 与实现关系
  • c#入门笔记(3)
  • 图像数据增强的高效执行
  • Linux下运行Jmeter压测
  • Kafka如何保证「消息不丢失」,「顺序传输」,「不重复消费」,以及为什么会发生重平衡(reblanace)
  • 攻克PostgreSQL专家认证
  • Git Commit 提交信息标准格式
  • Python打卡Day47 注意力热图可视化
  • 字符设备驱动、块设备驱动和网络设备驱动
  • Gitee仓库 日常操作详细步骤
  • Linux服务器性能优化总结
  • 【数据结构】快速排序算法精髓解析
  • shell脚本——搜索某个目录下带指定前缀的文件
  • 50.Seata-AT模式
  • Cyberduck (FTP和SFTP工具) v9.2.3.43590
  • 189.轮转数组
  • 设计模式的一些笔记
  • list集合可以一边遍历一遍修改元素吗?
  • Rust 入门 包 (二十一)
  • 计算机网络基础复习
  • 【数据分享】295个地级市互联网用户、邮电业务数据(2001-2022)
  • win10安装最新docker 4.44.2版图文教程(2025版)
  • 3.Shell脚本修炼手册之---Shell 变量基础知识