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

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.xdnf.cn/news/18425.html

相关文章:

  • 将集合拆分成若干个batch,并将batch存于新的集合
  • C语言第十章内存函数
  • C语言:第18天笔记
  • 【自记】Power BI 中 ALLNOBLANKROW的适用场景举例
  • 疏老师-python训练营-day51复习日+退款开始
  • 计算机网络技术学习-day4《路由器配置》
  • SQL 中大于小于号的表示方法总结
  • 微软宣布开源大模型gpt-oss在Azure平台实现性能突破
  • Git 新手完全指南(二):在vscode中使用git
  • 官网SSO登录系统的企业架构设计全过程
  • UNet改进(33):基于CBAM原理与PyTorch实战指南
  • Ubuntu 上安装 MongoDB
  • Hyperledger Fabric官方中文教程-改进笔记(十三)-使用测试网络创建通道
  • iOS 应用迭代与上架节奏管理 从测试包到正式发布的全流程实践
  • Scikit-learn 预处理函数分类详解
  • 阶跃星辰 StepFun 入驻 GitCode 平台,带来工业级 AI 体验
  • 密码加密算法和JWT无状态认证
  • [系统架构设计师]面向服务架构设计理论与实践(十五)
  • C++ 数据结构 和 STL
  • [Polly智能维护网络] 弹性上下文 | `ResiliencePropertyKey<TValue>`
  • WPF Alert弹框控件 - 完全使用指南
  • 2025年电赛A题省一方案
  • AR 虚实叠加技术在工业设备运维中的实现流程方案
  • 5G-A赋能AR眼镜:毫米级虚实融合的未来已来
  • 通过try-catch判断数据库唯一键字段是否重复
  • 网络流量分析——基础知识
  • MySQL 数据与表结构导出 Excel 技术文档
  • Ubuntu 主机名:精通配置与管理
  • Kafka-Eagle安装
  • SpringBoot + MyBatis-Plus 使用 listObjs 报 ClassCastException 的原因与解决办法