LeetCode hot100-3

java 复制代码
给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。

请你设计并实现时间复杂度为 O(n) 的算法解决此问题。

我的解法是可以通过的,我觉得比官方解法稍微好理解一点。

思路就是,排序之后判断相邻两个元素是否连续,由于有重复的还需要去重。而Set本身就可以去重+排序。

最常用的HashSet只能实现去重,不能排序的(既不是加进去的顺序,也不是自然排序的顺序),要用TreeSet(TreeSet是自然顺序1到9那种,还有个LinkedHashSet是元素添加顺序)。以及Set是不能直接得到第i个元素的,所以把set转成了List。还有集合的类型不能用int,要用包装成Integer。

java 复制代码
class Solution {
    public int longestConsecutive(int[] nums) {
        Set<Integer> s = new TreeSet<Integer>();
        for (int i = 0; i < nums.length; i++) {
            s.add(nums[i]);
        }
        List<Integer> l = new ArrayList<Integer>(s);
        // s.addAll(Arrays.asList(nums));
        int max = 1;
        int now = 1;
        for (int i = 0; i < l.size() - 1; i++) {
            if (l.get(i + 1) - l.get(i) == 1) {
                now++;
            } else {
                now = 1;
            }
            if (now > max) {
                max = now;
            }

        }
        if (nums.length == 0) {
            return 0;
        } else {
            return max;
        }

    }
}

官方解法

就是把最常见的两重循环优化了一下做了不必要情况下的跳出。在while循环中当前元素的往更大的找连续元素,看能找到几个。然后外层循环就是一个一个遍历,如果已经有更小的连续元素的话,那整个这个元素已经在while循环中找过了,就不再处理。

java 复制代码
class Solution {
    public int longestConsecutive(int[] nums) {
        Set<Integer> num_set = new HashSet<Integer>();
        for (int num : nums) {
            num_set.add(num);
        }

        int longestStreak = 0;

        for (int num : num_set) {
            if (!num_set.contains(num - 1)) {
                int currentNum = num;
                int currentStreak = 1;

                while (num_set.contains(currentNum + 1)) {
                    currentNum += 1;
                    currentStreak += 1;
                }

                longestStreak = Math.max(longestStreak, currentStreak);
            }
        }

        return longestStreak;
    }
}

作者:力扣官方题解
链接:https://leetcode.cn/problems/longest-consecutive-sequence/solutions/276931/zui-chang-lian-xu-xu-lie-by-leetcode-solution/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。
相关推荐
代码雕刻家2 分钟前
C语言中关于类型转换不匹配的解决方案
c语言·开发语言·算法
程序猿_极客28 分钟前
【2025】16届蓝桥杯 Java 组全题详解(省赛真题 + 思路 + 代码)
java·开发语言·职场和发展·蓝桥杯
星星的月亮叫太阳1 小时前
large-scale-DRL-exploration 代码阅读 总结
python·算法
王哈哈^_^1 小时前
YOLOv11视觉检测实战:安全距离测算全解析
人工智能·数码相机·算法·yolo·计算机视觉·目标跟踪·视觉检测
..Cherry..1 小时前
Etcd详解(raft算法保证强一致性)
数据库·算法·etcd
商汤万象开发者2 小时前
LazyLLM教程 | 第13讲:RAG+多模态:图片、表格通吃的问答系统
人工智能·科技·算法·开源·多模态
Lee_yayayayaya2 小时前
本原多项式产生m序列的原理
算法
蒙奇D索大3 小时前
【算法】递归的艺术:从本质思想到递归树,深入剖析算法的性能权衡
经验分享·笔记·算法·改行学it
王哈哈^_^3 小时前
【数据集+完整源码】水稻病害数据集,yolov8水稻病害检测数据集 6715 张,目标检测水稻识别算法实战训推教程
人工智能·算法·yolo·目标检测·计算机视觉·视觉检测·毕业设计
light_in_hand3 小时前
内存区域划分——垃圾回收
java·jvm·算法