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

leetcode Hot 100系列

文章目录


一、核心操作

  1. 用map,key为char,value为出现次数,将字符串中的值依次入栈,再判断次数是否大于1,如果大于1,则循环删除掉包括重复值之前的char
  2. 记录最大长度

提示:小白个人理解,如有错误敬请谅解!

二、外层配合操作

  1. 双指针操作

三、核心模式代码

代码如下:

c 复制代码
class Solution {
    public:
        int lengthOfLongestSubstring(std::string s) {
            std::unordered_map<char,int> umap;
            int res=0;
            for(int left=0,right=0;right<s.size();right++)
            {
                umap[s[right]]++;
                while(umap[s[right]]>1)
                {
                    umap[s[left++]]--;
                }
                res=std::max(res,right-left+1);
            }
            return res;
        }
    };

总结

  1. 先加入,后判断,循环删除重复值
相关推荐
Savior`L4 小时前
二分算法及常见用法
数据结构·c++·算法
mmz12075 小时前
前缀和问题(c++)
c++·算法·图论
努力学算法的蒟蒻5 小时前
day27(12.7)——leetcode面试经典150
算法·leetcode·面试
甄心爱学习6 小时前
CSP认证 备考(python)
数据结构·python·算法·动态规划
kyle~6 小时前
排序---常用排序算法汇总
数据结构·算法·排序算法
AndrewHZ7 小时前
【遥感图像入门】DEM数据处理核心算法与Python实操指南
图像处理·python·算法·dem·高程数据·遥感图像·差值算法
CoderYanger7 小时前
动态规划算法-子序列问题(数组中不连续的一段):28.摆动序列
java·算法·leetcode·动态规划·1024程序员节
有时间要学习7 小时前
面试150——第二周
数据结构·算法·leetcode
freedom_1024_7 小时前
红黑树底层原理拆解
开发语言·数据结构·b树