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. 先加入,后判断,循环删除重复值
相关推荐
自信150413057591 天前
初学者小白复盘15之指针(4)
c语言·数据结构·算法
郝学胜-神的一滴1 天前
Cesium绘制线:从基础到高级技巧
前端·javascript·程序人生·线性代数·算法·矩阵·图形渲染
东皇太星1 天前
机器学习概念,算法原理及应用
算法·机器学习·梯度下降法
.格子衫.1 天前
021数据结构之并查集——算法备赛
数据结构·算法
im_AMBER1 天前
Leetcode 35
笔记·学习·算法·leetcode
码农多耕地呗1 天前
力扣101.对称二叉树(java)
算法·leetcode
小龙报1 天前
《算法通关指南之C++编程篇(5)----- 条件判断与循环(下)》
c语言·开发语言·c++·算法·visualstudio·学习方法·visual studio
郝学胜-神的一滴1 天前
C++ STL(标准模板库)深度解析:从基础到实践
linux·服务器·开发语言·c++·算法
刚入坑的新人编程1 天前
算法训练.17
开发语言·数据结构·c++·算法
TinpeaV1 天前
String[ ] 和 List<String> 的区别
数据结构·list