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;
    }
};
相关推荐
Yzzz-F3 分钟前
牛客周赛round123 G小红出千[补题][滑动窗口]
算法
lkbhua莱克瓦2412 分钟前
多线程综合练习3
java·开发语言·多线程·githup
肆悟先生20 分钟前
3.16 含有可变参数的函数
c++·算法
步步为营DotNet25 分钟前
深度解析.NET中属性(Property)的幕后机制:优化数据访问与封装
java·算法·.net
Swift社区25 分钟前
LeetCode 454 - 四数相加 II
java·算法·leetcode
想做后端的小C27 分钟前
Java:访问权限
java·开发语言
啃火龙果的兔子27 分钟前
java语言基础
java·开发语言·python
tokepson28 分钟前
反向传播
深度学习·算法·ai·反向传播
禾高网络31 分钟前
互联网医院定制|互联网医院|禾高互联网医院搭建
java·大数据·人工智能·小程序
掘根33 分钟前
【消息队列项目】消费者管理模块实现
java·开发语言