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;
    }
};
相关推荐
麦麦鸡腿堡2 分钟前
Java事件处理机制
java·开发语言·python
xier_ran3 分钟前
力扣(LeetCode)100题:41.缺失的第一个正数
数据结构·算法·leetcode
小画家~29 分钟前
第二十八:golang Time.time 时间格式返回定义结构体
java·前端·golang
西岭千秋雪_35 分钟前
Kafka安装和使用
java·分布式·kafka·java-zookeeper
Swift社区40 分钟前
LeetCode 425 - 单词方块
算法·leetcode·职场和发展
從南走到北1 小时前
JAVA国际版打车APP打车顺风车滴滴车跑腿APP源码Android+IOS+H5
android·java·ios
Java天梯之路1 小时前
如何接收前端参数
java·后端
独自破碎E1 小时前
从括号匹配到字符串解码:递归思想的巧妙应用
android·java·开发语言
忧郁的橙子.1 小时前
二、Rabbit MQ 高级
java·开发语言
weixin_307779131 小时前
软件演示环境动态扩展与成本优化:基于目标跟踪与计划扩展的AWS Auto Scaling策略
算法·云原生·云计算·aws