leetcode3.无重复字符的最长字串

采用滑动窗口方法

cpp 复制代码
class Solution {
public:
    int lengthOfLongestSubstring(string s) {
        int n=s.size();
        if(n==0)
            return 0;
        int result=0;
        unordered_set<char> set;
        set.insert(s[0]);
        for(int i=0,j=0;i<n;i++){
            while(j+1<n&&set.find(s[j+1])==set.end()){
                set.insert(s[j+1]);
                j++;
            }
            result=max(result,j-i+1);
            set.erase(s[i]);
        }
        return result;
    }
};
相关推荐
oioihoii30 分钟前
深入解析 C++20 中的 std::bind_front:高效函数绑定与参数前置
java·算法·c++20
MobiCetus1 小时前
如何一键安装所有Python项目的依赖!
开发语言·jvm·c++·人工智能·python·算法·机器学习
思麟呀1 小时前
String类的模拟实现
开发语言·c++·算法
Dante7981 小时前
判断质数及其优化方法
开发语言·c++·算法
ylfhpy2 小时前
Java面试黄金宝典19
java·开发语言·数据结构·算法·面试·面经
不知名。。。。。。。。2 小时前
C++———— Vector
c++·算法·vector
姜威鱼2 小时前
蓝桥杯python编程每日刷题 day 20
数据结构·算法·蓝桥杯
longlong int2 小时前
【每日算法】Day 9-1:贪心算法精讲——区间调度与最优选择(C++实现)
算法·贪心算法
张琪杭3 小时前
python算法:leetcode二叉树相关算法题
python·算法·leetcode·职场和发展
LIUJH12333 小时前
哈希冲突 及 双哈希
开发语言·数据结构·c++·算法·哈希算法