hot100 3.无重复字符的最长子串

思路:滑动窗口。

复杂度分析:

1.时间复杂度:O(n)。

2.空间复杂度:O(1)。

(一)方法一:整型数组

java 复制代码
class Solution {
    public int lengthOfLongestSubstring(String s) {
        char[] chars = s.toCharArray();
        int n = chars.length;
        int res = 0;
        int left = 0;
        int[] cnt = new int[128]; //ASCII码的字符集有128个字符
        for(int right = 0;right < n;right++){
            char c = chars[right];
            cnt[c]++;
            while(cnt[c] > 1){ //窗口内有重复元素
                cnt[chars[left]]--; //移除窗口左端点字母
                left++; //缩小窗口
            }
            res = Math.max(res,right - left + 1); //更新窗口长度的最大值
        }
        return res;
    }
}

(二)方法二:布尔数组

java 复制代码
class Solution {
    public int lengthOfLongestSubstring(String s) {
        char[] chars = s.toCharArray();
        int n = chars.length;
        int res = 0;
        int left = 0;
        boolean[] has = new boolean[128]; //ASCII码的字符集有128个字符
        for(int right = 0;right < n;right++){
            char c = chars[right];
            // 如果窗口已经包含c,那么再加入一个c会导致窗口内有重复元素
            // 所以要在加入c之前,先移出窗口内的c
            while(has[c]){ //窗口内有c
                has[chars[left]] = false;
                left++; //缩小窗口
            }
            has[c] = true; //加入c
            res = Math.max(res,right - left + 1); //更新窗口长度的最大值
        }
        return res;
    }
}
相关推荐
地平线开发者8 小时前
SparseDrive 模型导出与性能优化实战
算法·自动驾驶
董董灿是个攻城狮9 小时前
大模型连载2:初步认识 tokenizer 的过程
算法
地平线开发者9 小时前
地平线 VP 接口工程实践(一):hbVPRoiResize 接口功能、使用约束与典型问题总结
算法·自动驾驶
罗西的思考9 小时前
AI Agent框架探秘:拆解 OpenHands(10)--- Runtime
人工智能·算法·机器学习
HXhlx13 小时前
CART决策树基本原理
算法·机器学习
Wect13 小时前
LeetCode 210. 课程表 II 题解:Kahn算法+DFS 双解法精讲
前端·算法·typescript
颜酱14 小时前
单调队列:滑动窗口极值问题的最优解(通用模板版)
javascript·后端·算法
Gorway20 小时前
解析残差网络 (ResNet)
算法
拖拉斯旋风21 小时前
LeetCode 经典算法题解析:优先队列与广度优先搜索的巧妙应用
算法
Wect21 小时前
LeetCode 207. 课程表:两种解法(BFS+DFS)详细解析
前端·算法·typescript