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

一、问题描述

二、解题思路

整体思路:

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

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

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

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

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

若字符串为"a bcabcbb",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)

cpp 复制代码
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;
    }
};
相关推荐
你撅嘴真丑1 小时前
第九章-数字三角形
算法
在路上看风景2 小时前
19. 成员初始化列表和初始化对象
c++
uesowys2 小时前
Apache Spark算法开发指导-One-vs-Rest classifier
人工智能·算法·spark
zmzb01032 小时前
C++课后习题训练记录Day98
开发语言·c++
ValhallaCoder2 小时前
hot100-二叉树I
数据结构·python·算法·二叉树
董董灿是个攻城狮2 小时前
AI 视觉连载1:像素
算法
念风零壹2 小时前
C++ 内存避坑指南:如何用移动语义和智能指针解决“深拷贝”与“内存泄漏”
c++
智驱力人工智能2 小时前
小区高空抛物AI实时预警方案 筑牢社区头顶安全的实践 高空抛物检测 高空抛物监控安装教程 高空抛物误报率优化方案 高空抛物监控案例分享
人工智能·深度学习·opencv·算法·安全·yolo·边缘计算
孞㐑¥3 小时前
算法——BFS
开发语言·c++·经验分享·笔记·算法
月挽清风3 小时前
代码随想录第十五天
数据结构·算法·leetcode