力扣-hot100(无重复字符的最长子串)

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

中等

给定一个字符串 s ,请你找出其中不含有重复字符的 最长 子串 的长度。

示例 1:

复制代码
输入: s = "abcabcbb"
输出: 3 
解释: 因为无重复字符的最长子串是 "abc",所以其长度为 3。

暴力直观解法一:

思路: 手动看题: -> O -> 不重复字符? os: 有没有这样一种数据结构....,有的兄弟有的。队列报你身份证了。 维护一个队列,每次往队列中加入元素,就去看看队列中是否有一个相同的元素已经在里面了,如果有,就把元素从前往后进行结算,再将该元素加入队列中,以此类推,得到最长子串.

复制代码
class Solution {
    public int lengthOfLongestSubstring(String s) {
        Queue<Character> queue = new LinkedList<>();
        int n = s.length();
        int maxlen = 0;
        int len = 0;
        for(int i = 0; i < n; i ++){
            char c = s.charAt(i);
            // 判断队列中是否存在这么一个元素
            boolean std = queue.contains(c);
            // 还存在重复元素则把前面的不断进行移除
            if(std){
                while(queue.contains(c)){
                     queue.remove();
                     len--;
                }
            }
            // 移除完了就可以加入进行 
            queue.add(c);
            len ++;
            maxlen = Math.max(maxlen, len);
        }
        return maxlen;
    }
}

执行用时分布 18ms 击败10.70%

神魔 才10.70% OVO。观察上述代码主要耽误我时间的地方就是检查这个元素 queue.contains(c); -> O(n)。神魔在我的代码中怎么能有这种坏东西。

不服,再来

解法二: 用Set来维护这些元素(set.contains(c)的时间复杂度为O(1)),那怎么保留队列的性质呢? 我们只需要在加入元素的时候一直加加加,加到厌倦(出现了重复元素),然后移除的时候只需要移除掉那个重复元素就行

复制代码
class Solution {
    public int lengthOfLongestSubstring(String s) {
        Set<Character> set = new HashSet<Character>();
        int len = s.length();
        int right = 0;
        int maxNumber = 0;
        for(int i = 0; i < len; i ++){
            // 除了第一次加入元素外,其它都是上一轮加到重复了才会停止,所以将上一个字符移除
            if(i != 0) set.remove(s.charAt(i - 1));
​
            // 加加加,加到厌倦
            while(right < len && !set.contains(s.charAt(right))){
                set.add(s.charAt(right));
                right ++;
            }
            maxNumber = Math.max(maxNumber, right  - i);
        }
        return maxNumber;
    }
}

6ms击败 67.99%

相关推荐
愚润求学15 分钟前
【数据结构】红黑树
数据结构·c++·笔记
竹下为生17 分钟前
LeetCode --- 154双周赛
算法·leetcode·哈希算法
xxjiaz20 分钟前
二分查找-LeetCode
java·数据结构·算法·leetcode
算法练习生41 分钟前
数据结构学习笔记 :排序算法详解与C语言实现
数据结构·学习·排序算法
爱的叹息1 小时前
【java实现+4种变体完整例子】排序算法中【插入排序】的详细解析,包含基础实现、常见变体的完整代码示例,以及各变体的对比表格
java·算法·排序算法
爱的叹息2 小时前
【java实现+4种变体完整例子】排序算法中【快速排序】的详细解析,包含基础实现、常见变体的完整代码示例,以及各变体的对比表格
java·算法·排序算法
C灿灿数模2 小时前
2025mathorcup妈妈杯数学建模挑战赛C题:汽车风阻预测,详细思路,模型,代码更新中
人工智能·算法·ffmpeg
Pasregret2 小时前
迭代器模式:统一不同数据结构的遍历方式
数据结构·迭代器模式
周Echo周2 小时前
16、堆基础知识点和priority_queue的模拟实现
java·linux·c语言·开发语言·c++·后端·算法
东雁西飞3 小时前
MATLAB 控制系统设计与仿真 - 39
开发语言·算法·matlab·自动化·工业机器人