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;
    }
};
相关推荐
Shan120514 小时前
算法案例精讲:连接所有点的最小费用
算法
迈巴赫车主14 小时前
蓝桥杯21241灯塔java
java·开发语言·数据结构·算法·职场和发展·蓝桥杯·动态规划
wabs66614 小时前
关于贪心算法【968.监控二叉树】的想法
算法·贪心算法
め.14 小时前
GJK+EPA算法
算法
兰令水14 小时前
【agent第3篇】agent上下文+面经
java·大数据·数据库
木井巳14 小时前
【DFS解决floodfill算法】岛屿数量
java·算法·leetcode·深度优先
弹简特14 小时前
【Java项目-轻聊】08-用户管理模块-实现获取用户信息+头像上传+显示头像
java·开发语言·springboot
贺国亚14 小时前
Buy领域智能体-Spring-AI全量工程
java·人工智能·spring
不想吃饭e14 小时前
uniapp-图片,视频上传组件封装
java·uni-app·音视频
迷藏49415 小时前
双阶段动态权重匹配系统:高效精准的工业级解决方案
java·junit