leetcode: 3无重复字符的最长子串。滑动窗口,c语言

给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串的长度。

示例 1:

复制代码
输入: s = "abcabcbb"
输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。

示例 2:

复制代码
输入: s = "bbbbb"
输出: 1
解释: 因为无重复字符的最长子串是 "b",所以其长度为 1。

示例 3:

复制代码
输入: s = "pwwkew"
输出: 3
解释: 因为无重复字符的最长子串是 "wke",所以其长度为 3。
     请注意,你的答案必须是 子串 的长度,"pwke" 是一个子序列,不是子串。

提示:

  • 0 <= s.length <= 5 * 104
  • s 由英文字母、数字、符号和空格组成

思路:双指针,右指针每前进一次,就从左指针开始检查一次,看从左指针开始到右指针前一个数(左闭右开区间)有没有和右指针相等的。如果没有,这就是一个无重复字符的子串,如果有就让左指针跳到这个字符的下一个位置,因为这个字符和右指针所在字符重复了。

检查结束之后,记录下长度。

时间复杂度O(n);

空间复杂度O(1);

cpp 复制代码
int lengthOfLongestSubstring(char* s) {
    if(!*s)//数组长度为0时直接返回0;
    {
        return 0;
    }
    int ans=1;//默认为1,如果数组长度不为0,那么最小为1。有更长的会覆盖1
    int left=0;//窗口左边界
    int right=1;//窗口右边界
    while(s[right])
    {int i=left;//检查是否重复的变量
        for(;i<right;i++)//检查是否重复,右边界走一次就检查一次
        {
            if(s[i]==s[right])
            {
                left=i+1;//跳到该重复字符的下一个位置,因为s[i]==s[right]
                break;//重复就跳出循环
            }
        }   
     if(i==right)//完整的走完了循环才比较长度,删去这层if也行。
        {
            if(right-left+1>ans)//+1是因为,比如1-0=1,但是0------1是有两个元素的,即s[0]和s[1]
            {
                ans=right-left+1;
            }
        }
        right++;//右边界继续往前走
    }
    return ans;
}
相关推荐
zyd09152 小时前
代码随想录Day50:图论(图论理论、深度搜索理论、所有可达路径、广度搜索理论)
java·数据结构·算法·leetcode·图论
奶黄小甜包6 小时前
C语言零基础第16讲:内存函数
c语言·笔记·学习
现在,此刻12 小时前
leetcode 11. 盛最多水的容器 -java
java·算法·leetcode
源远流长jerry13 小时前
OpenHarmony概述与使用
c语言·c++·鸿蒙系统
艾莉丝努力练剑13 小时前
深入详解C语言的循环结构:while循环、do-while循环、for循环,结合实例,讲透C语言的循环结构
c语言·开发语言·c++·学习
火车叨位去194915 小时前
力扣top100(day01-05)--矩阵
算法·leetcode·矩阵
晨非辰15 小时前
#C语言——学习攻略:自定义类型路线--结构体--结构体类型,结构体变量的创建和初始化,结构体内存对齐,结构体传参,结构体实现位段
c语言·开发语言·经验分享·学习·其他·学习方法·visual studio
·白小白16 小时前
【数据结构】——栈(Stack)的原理与实现
c语言·开发语言·数据结构
冬夜戏雪17 小时前
java学习 leetcode 二分查找 图论
java·学习·leetcode
KFCgrandpahhh17 小时前
从0开始跟小甲鱼C语言视频使用linux一步步学习C语言(持续更新)8.13
linux·c语言·学习