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;
    }
};
相关推荐
顾人间讥诘1 分钟前
卡特兰数及相关应用场景
算法
天骄t2 分钟前
深入解析栈:数据结构与系统栈
java·开发语言·数据结构
CoderYanger4 分钟前
A.每日一题——3625. 统计梯形的数目 II
java·算法·leetcode·职场和发展
Dolphin_Home4 分钟前
接口字段入参出参分离技巧:从注解到DTO分层实践
java·spring boot·后端
松涛和鸣5 分钟前
24、数据结构核心:队列与栈的原理、实现与应用
c语言·开发语言·数据结构·学习·算法
卿雪6 分钟前
MySQL【存储引擎】:InnoDB、MyISAM、Memory...
java·数据库·python·sql·mysql·golang
即随本心0.o10 分钟前
大模型springai,Rag,redis-stack向量数据库存储
java·数据库·redis
豐儀麟阁贵10 分钟前
9.1String类
java·开发语言·算法
okseekw13 分钟前
Java内部类实战指南:4种类型+5个经典场景,开发效率直接拉满!
java·后端
三炭先生15 分钟前
计算机视觉算法--第一章:概述
人工智能·算法·计算机视觉