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;
    }
};
相关推荐
源码君miui520861 分钟前
JAVA国际版同城服务同城信息同城任务发布平台APP源码Android + IOS
android·java·ios
想唱rap15 分钟前
Linux下进程的状态和优先级
linux·运维·服务器·开发语言·数据结构·算法
鹿衔`19 分钟前
解决Flink on Yarn模式多Yarn Session会话提交
java·前端·flink
静若繁花_jingjing35 分钟前
SpringBoot/SpringMvc/SpringCloud
java·spring boot·spring cloud
q***046335 分钟前
【springboot】Spring 官方抛弃了 Java 8!新idea如何创建java8项目
java·spring boot·spring
稚辉君.MCA_P8_Java36 分钟前
Sqoop 实现的功能是什么
java·服务器·架构·kubernetes·sqoop
普通网友37 分钟前
单元测试在C++项目中的实践
开发语言·c++·算法
w***48137 分钟前
【Spring】IDEA中创建Spring项目
java·spring·intellij-idea
Thexhy43 分钟前
Java大模型后端开发全流程指南
java·ai·大模型
Croa-vo1 小时前
逆袭Akuna Quant!美硕秋招亲历,从网申到拿offer全攻略
数据结构·经验分享·算法·面试·职场和发展