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;
    }
};
相关推荐
超级码力6664 小时前
【Latex文件架构】Latex文件架构模板
算法·数学建模·信息可视化
穿条秋裤到处跑5 小时前
每日一道leetcode(2026.04.29):二维网格图中探测环
算法·leetcode·职场和发展
Merlos_wind5 小时前
HashMap详解
算法·哈希算法·散列表
汉克老师6 小时前
GESP2025年3月认证C++五级( 第三部分编程题(1、平均分配))
c++·算法·贪心算法·排序·gesp5级·gesp五级
Yzzz-F8 小时前
Problem - 2205D - Codeforces
算法
智者知已应修善业9 小时前
【51单片机2个按键控制流水灯运行与暂停】2023-9-6
c++·经验分享·笔记·算法·51单片机
Halo_tjn9 小时前
Java Set集合相关知识点
java·开发语言·算法
生成论实验室9 小时前
《事件关系阴阳博弈动力学:识势应势之道》第四篇:降U动力学——认知确定度的自驱演化
人工智能·科技·神经网络·算法·架构
AI科技星10 小时前
全域数学·72分册:场计算机卷【乖乖数学】
算法·机器学习·数学建模·数据挖掘·量子计算
科研前沿11 小时前
镜像孪生VS视频孪生核心技术产品核心优势
大数据·人工智能·算法·重构·空间计算