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

给定一个字符串 s ,请你找出其中不含有重复字符的 最长子串 的长度

cpp 复制代码
输入: s = "abcabcbb"
输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。

转载: C++常用语法------unordered_set

题目主要思想:滑动窗口

一个队列"abcabcbb",进入这个队列为"abc"满足题意,当再进入"a",队列就变成了"abca",不满足题意,所以我们需要移动队列左边的元素,直到满足题意即可

cpp 复制代码
class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        set<char> repeat;
        int len=s.size();
        int rp=-1,count=0;
        for(int i=0;i<len;i++){
            if(i!=0)
            	//删除a,继续往后加
                repeat.erase(s[i-1]);
            //无重复字符abc
            while(rp+1<len&&!repeat.count(s[rp+1])){
                repeat.insert(s[rp+1]);
                rp++;
            }
            //比较最大
            count=max(count,rp-i+1);
        }
        return count;
    }
};
相关推荐
m0_748248022 分钟前
C++ 异常处理全解析:从语法到设计哲学
java·c++·word
仟濹3 分钟前
IDEA 软件下载 + 安装 | 操作步骤
java·ide·intellij-idea
小白程序员成长日记4 分钟前
2025.11.08 力扣每日一题
算法·leetcode·职场和发展
Nebula_g12 分钟前
C语言应用实例:学生管理系统1(指针、结构体综合应用,动态内存分配)
c语言·开发语言·学习·算法·基础
小叮当⇔12 分钟前
“征服式学习”提示词工具箱
学习·算法
毕设源码-赖学姐13 分钟前
【开题答辩全过程】以 法院信访投诉平台为例,包含答辩的问题和答案
java·eclipse
惊讶的猫15 分钟前
字符串- 字符串转换整数 (atoi)
数据结构·算法
依_旧24 分钟前
MySQL下载安装配置(超级超级入门级)
java·后端
淘源码d41 分钟前
什么是医院随访系统?成熟在用的智慧随访系统源码
java·spring boot·后端·开源·源码·随访系统·随访系统框架
@小码农1 小时前
2025年北京海淀区中小学生信息学竞赛第一赛段试题(附答案)
人工智能·python·算法·蓝桥杯