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;
    }
};
相关推荐
仰泳的熊猫3 分钟前
1149 Dangerous Goods Packaging
数据结构·c++·算法·pat考试
ALex_zry3 分钟前
现代C++如何解决传统内存分配器的核心痛点
java·c++·spring
Coder_Boy_5 分钟前
【人工智能应用技术】-基础实战-小程序应用(基于springAI+百度语音技术)智能语音控制-Java部分核心逻辑
java·开发语言·人工智能·单片机
MACKEI5 分钟前
业务域名验证文件添加操作手册
java·开发语言
roman_日积跬步-终至千里6 分钟前
【源码分析】StarRocks EditLog 写入与 Replay 完整流程分析
java·网络·python
apihz8 分钟前
货币汇率换算免费API接口(每日更新汇率)
android·java·开发语言
_OP_CHEN9 分钟前
【算法基础篇】(三十七)图论基础之多源最短路:Floyd 算法吃透所有点对最短路径!
算法·蓝桥杯·图论·算法竞赛·floyd算法·acm/icpc·多源最短路
Web极客码9 分钟前
如何选择最适合的内容管理系统(CMS)?
java·数据库·算法
爱笑的眼睛1111 分钟前
Flask上下文API:从并发陷阱到架构原理解析
java·人工智能·python·ai
asdfg125896316 分钟前
数组去重(JS)
java·前端·javascript