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

leetcode3 无重复字符的最长子串

一、问题描述

二、解题思路

整体思路:

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

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

(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/341456.html

相关文章:

  • vue2封装日期选择组件--有时间选择版本
  • 创建Vue项目的不同方式及项目规范化配置
  • Playwright 与 Scrapy 的实际应用场景能力分析
  • 深入理解 Spring 的 @ControllerAdvice
  • 【AI应用】修改向量数据库Milvus默认密码
  • KylinV10服务器版和桌面版SVN搭建步骤
  • python中view把矩阵维度降低的时候是什么一个排序顺序
  • 深度解析LangChain:LLM应用开发利器
  • Linux: network: arp: arp_accept
  • linux内核 - 内存管理单元(MMU)与地址翻译(二)
  • 直播预告|鸿蒙全场景开发指南
  • 【GPT入门】第50课 LlamaFacotory 客观评估模型效果
  • 接美国血统(中序、后序→前序)
  • 如何让FastAPI任务系统在失败时自动告警并自我修复?
  • Frida 动态 Hook 安卓 WebView 与第三方内核完全指南
  • 一种数字相机中的自动曝光算法
  • 01-Docker概述
  • 多摄像头多算法智能监控系统设计与实现
  • 关于 preprocessing.scale 函数
  • 机器语言、操作系统与硬件执行:深入解析计算机的底层逻辑
  • 【C++】模版(初阶)
  • 从“怀疑作弊”到“实锤取证”:在线面试智能监考重塑招聘公信力
  • CLEAN 函数
  • HTML 简明教程
  • Python 属性封装(Attribute Encapsulation)
  • Docker在Linux中安装与使用教程
  • ubuntu privileged cont 一直在读取硬盘
  • ubuntu24.04 frps服务器端自动启动设置【2025-08-20】
  • JUC之CompletableFuture【下】
  • 内网安全——出网协议端口探测