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;
    }
};
相关推荐
甜鲸鱼15 小时前
【Spring Boot + OpenAPI 3】开箱即用的 API 文档方案(SpringDoc + Knife4j)
java·spring boot·后端
robch15 小时前
Java后端优雅的实现分页搜索排序-架构2
java·开发语言·架构
她说..15 小时前
在定义Java接口参数时,遇到整数类型,到底该用int还是Integer?
java·开发语言·java-ee·springboot
两广总督是码农15 小时前
IDEA-SpringBoot热部署
java·spring boot·intellij-idea
程序员-King.15 小时前
day110—同向双指针(数组)—最多K个重复元素的最长子数组(LeetCode-2958)
算法·leetcode·双指针
MoFe115 小时前
【.net/.net core】【报错处理】另一个 SqlParameterCollection 中已包含 SqlParameter。
java·.net·.netcore
sang_xb15 小时前
深入解析 HashMap:从存储架构到性能优化
android·java·性能优化·架构
做怪小疯子15 小时前
LeetCode 热题 100——二叉树——二叉树的右视图
算法·leetcode·职场和发展
Swift社区15 小时前
LeetCode 442 - 数组中重复的数据
算法·leetcode·职场和发展
努力学算法的蒟蒻15 小时前
day25(12.5)——leetcode面试经典150
算法·leetcode·职场和发展