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;
    }
}
相关推荐
见合八方5 分钟前
【滤波器】热调谐FP滤波器
人工智能·算法
古城小栈6 分钟前
cargo-pprof:Rust性能调优
人工智能·算法·rust
x_xbx17 分钟前
LeetCode:543. 二叉树的直径
算法·leetcode·职场和发展
QiLinkOS18 分钟前
QiLink 技术委员会选举实施细则
c语言·数据结构·c++·单片机·嵌入式硬件·算法·开源
我材不敲代码21 分钟前
Python基础: 函数超全详解:定义、参数、返回值、作用域与递归
开发语言·python·算法
无忧.芙桃23 分钟前
数据结构之顺序表的实现
数据结构
罗超驿27 分钟前
11.LeetCode 1004. 最大连续1的个数 III | 滑动窗口解法详解(Java)
java·算法·leetcode
我叫张小白。31 分钟前
Redis的缓存雪崩、击穿、穿透和解决方案
数据结构·redis·fastapi·缓存穿透·缓存击穿·雪崩·热点key问题
QiLinkOS31 分钟前
发明人与专利价值共生逻辑
c语言·数据结构·c++·人工智能·单片机·嵌入式硬件·算法
计算机安禾43 分钟前
【算法分析与设计】第21篇:回溯法的状态空间树与剪枝函数设计
大数据·人工智能·算法·机器学习·数据挖掘·剪枝