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;
    }
};
相关推荐
智驱力人工智能几秒前
矿山皮带锚杆等异物识别 从事故预防到智慧矿山的工程实践 锚杆检测 矿山皮带铁丝异物AI预警系统 工厂皮带木桩异物实时预警技术
人工智能·算法·安全·yolo·目标检测·计算机视觉·边缘计算
忆锦紫4 分钟前
图像降噪算法:中值滤波算法及MATLAB实现
图像处理·算法·matlab
知乎的哥廷根数学学派5 分钟前
基于多分辨率注意力脉冲神经网络的机械振动信号故障诊断算法(西储大学轴承数据,Pytorch)
人工智能·pytorch·深度学习·神经网络·算法·机器学习
kebijuelun17 分钟前
Qwen 团队提出 ArenaRL:面向开放式 Agent RL 任务
人工智能·算法·语言模型·transformer
机器学习之心19 分钟前
PSO优化的K-means++聚类算法用于用户用电行为分析的实现方案
算法·kmeans·聚类
小黄鸭code22 分钟前
C++ 算法笔试题(常见算法版)
c++·算法·排序算法
lixinnnn.25 分钟前
优先级队列:最小函数值
数据结构·算法
Xの哲學28 分钟前
Linux Worklet 深入剖析: 轻量级延迟执行机制
linux·服务器·网络·数据结构·算法
666HZ66630 分钟前
数据结构2.1 线性表习题
c语言·数据结构·算法
lihao lihao36 分钟前
C++ set和map
开发语言·c++·算法