LeetCode 3. 无重复字符的最长子串

题目链接

力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台

题目解析

我们需要找的是含重复元素的最长子串,当然直接暴力求解固然简单。但是可能引发的情况是超时,而且面试官想看到的也不是让你去暴力解决这类问题。因此我们使用哈希+滑动窗口的思想来解决。

滑动窗口+哈希

使用哈希表的缘故是更好的判断,该字符是否是重复的元素。

将当前元素进行进窗口,如果该元素是重复的元素。那么从该窗口的左边进行出窗口,直到该元素不是重复的元素为止,每次进窗口之后统计当前无重复子串的长度,求出最长的长度并且返回,代码如下(含有详细注释)。

代码

cpp 复制代码
class Solution 
{
public:
    int lengthOfLongestSubstring(string s) 
    {
        int n=s.size();
        // 注意字符的范围,定义哈希表
        int hash[128]={0};
        int ret=0;
        for(int left=0,right=0;right<n;right++)
        {
            // 进窗口
            hash[s[right]]++;
            // 若有重复元素,则进入循环
            while(hash[s[right]]>1)
            {
                // 最左边元素出窗口
                hash[s[left]]--;
                // 更新窗口
                left++;
            }
            // 走到这里right与left之间组成的字符串肯定没有重复元素
            // 计算长度
            ret=max(ret,right-left+1);
        }
        return ret;
    }
};
相关推荐
源代码•宸2 小时前
分布式缓存-GO(分布式算法之一致性哈希、缓存对外服务化)
开发语言·经验分享·分布式·后端·算法·缓存·golang
yongui478342 小时前
MATLAB的指纹识别系统实现
算法
高山上有一只小老虎2 小时前
翻之矩阵中的行
java·算法
jghhh013 小时前
RINEX文件进行卫星导航解算
算法
爱思德学术3 小时前
中国计算机学会(CCF)推荐学术会议-A(计算机科学理论):LICS 2026
算法·计算机理论·计算机逻辑
CVHub3 小时前
多模态图文训推一体化平台 X-AnyLabeling 3.0 版本正式发布!首次支持远程模型推理服务,并新增 Qwen3-VL 等多款主流模型及诸多功能特性,等
算法
hoiii1873 小时前
MATLAB实现Canny边缘检测算法
算法·计算机视觉·matlab
qq_430855883 小时前
线代第二章矩阵第四课:方阵的幂
算法·机器学习·矩阵
roman_日积跬步-终至千里3 小时前
【计算机设计与算法-习题2】动态规划应用:矩阵乘法与钢条切割问题
算法·矩阵·动态规划
kupeThinkPoem3 小时前
计算机算法导论第三版算法视频讲解
数据结构·算法