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 小时前
分布式缓存-GO(分布式算法之一致性哈希、缓存对外服务化)
开发语言·经验分享·分布式·后端·算法·缓存·golang
It's now2 小时前
Spring AI 基础开发流程
java·人工智能·后端·spring
cxh_陈2 小时前
线程的状态,以及和锁有什么关系
java·线程·线程的状态·线程和锁
计算机毕设VX:Fegn08952 小时前
计算机毕业设计|基于springboot + vue图书商城系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·课程设计
R.lin2 小时前
Java 8日期时间API完全指南
java·开发语言·python
毕设源码-赖学姐3 小时前
【开题答辩全过程】以 高校教学质量监控平台为例,包含答辩的问题和答案
java·eclipse
yongui478343 小时前
MATLAB的指纹识别系统实现
算法
高山上有一只小老虎3 小时前
翻之矩阵中的行
java·算法
jghhh013 小时前
RINEX文件进行卫星导航解算
算法
火钳游侠3 小时前
java单行注释,多行注释,文档注释
java·开发语言