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;
    }
};
相关推荐
Swift社区3 分钟前
LeetCode 405 - 数字转换为十六进制数
算法·leetcode·职场和发展
赵杰伦cpp6 分钟前
数据结构——二叉搜索树深度解析
开发语言·数据结构·c++·算法
大数据张老师20 分钟前
数据结构——希尔排序
数据结构·算法·排序算法·1024程序员节
冬夜戏雪27 分钟前
[学习日记]看书笔记
java·学习
初级程序员Kyle31 分钟前
开始改变第一天 JVM的原理到调优(2)
java·面试
程序员三明治1 小时前
Spring AOP:注解配置与XML配置双实战
java·后端·spring·代理模式·aop·1024程序员节
第七序章1 小时前
【C + +】unordered_set 和 unordered_map 的用法、区别、性能全解析
数据结构·c++·人工智能·算法·哈希算法·1024程序员节
DKPT1 小时前
JVM直接内存和堆内存比例如何设置?
java·jvm·笔记·学习·spring
草莓熊Lotso1 小时前
《算法闯关指南:优选算法--二分查找》--23.寻找旋转排序数组中的最小值,24.点名
开发语言·c++·算法·1024程序员节