LeetCode 刷题【128. 最长连续序列】

128. 最长连续序列

自己做

解1:排序

java 复制代码
class Solution {
    public int longestConsecutive(int[] nums) {
        if(nums.length == 0)
            return 0;

        //排序
        Arrays.sort(nums);

        int max = 1;
        int len = 1;

        for(int i = 1; i < nums.length; i++){
            if(i > 1 && nums[i] == nums[i - 1])
                nums[i - 1] = nums[i - 2];
            else if(nums[i] == nums[i - 1] + 1)
                len++;
            else
                len = 1;

            if(len > max)
                max = len;
        }

        return max;
    }
}

看题解

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;
    }
}
相关推荐
AI科技星4 分钟前
基于v≡c第一性原理的大统一力方程:严格推导、全维度验证与四大基本相互作用的统一
人工智能·线性代数·算法·机器学习·平面
小杍随笔6 分钟前
【Rust 语言编程知识与应用:同步机制详解】
开发语言·算法·rust
sprite_雪碧8 分钟前
枚举 / 搜索类算法(机试核心考点)
算法
罗湖老棍子14 分钟前
简单题(信息学奥赛一本通- P1539)
数据结构·算法·树状数组·区间修改 单点查询
圣保罗的大教堂21 分钟前
leetcode 1594. 矩阵的最大非负积 中等
leetcode
羊小猪~~21 分钟前
【论文精度】Transformer---大模型基石
人工智能·深度学习·考研·算法·机器学习·transformer
西西弟34 分钟前
常见排序算法集合(数据结构)
数据结构·算法·排序算法
Yzzz-F39 分钟前
[模板]Nim博弈
算法
小龙报39 分钟前
【数据结构与算法】栈和队列的综合应用:1.用栈实现队列 2.用队列实现栈 3.设计循环队列
c语言·数据结构·数据库·c++·redis·算法·缓存
重生之我是Java开发战士1 小时前
【广度优先搜索】队列:N叉树的层序遍历,二叉树的锯齿形层序遍历,二叉树的最大宽度,在每个树行中找最大值
数据结构·算法·leetcode·广度优先