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;
    }
}
相关推荐
逑之14 分钟前
C语言笔记10:sizeof和strlen,指针与数组
c语言·笔记·算法
求梦82018 分钟前
【力扣hot100题】旋转图像(15)
算法·leetcode·职场和发展
C雨后彩虹5 小时前
任务最优调度
java·数据结构·算法·华为·面试
少林码僧7 小时前
2.31 机器学习神器项目实战:如何在真实项目中应用XGBoost等算法
人工智能·python·算法·机器学习·ai·数据挖掘
钱彬 (Qian Bin)7 小时前
项目实践15—全球证件智能识别系统(切换为Qwen3-VL-8B-Instruct图文多模态大模型)
人工智能·算法·机器学习·多模态·全球证件识别
Niuguangshuo7 小时前
EM算法详解:解密“鸡生蛋“的机器学习困局
算法·机器学习·概率论
a3158238067 小时前
Android 大图显示策略优化显示(一)
android·算法·图片加载·大图片
一条大祥脚8 小时前
26.1.9 轮廓线dp 状压最短路 构造
数据结构·c++·算法
鲨莎分不晴8 小时前
反向传播的数学本质:链式法则与动态规划的完美共舞
算法·动态规划
sonadorje8 小时前
逻辑回归中的条件概率
算法·机器学习·逻辑回归