LeetCode:最长连续序列

java 复制代码
class Solution {
    public int longestConsecutive(int[] nums) {
        Set<Integer> set = new HashSet<>();
        //将数组中的数字存到set集合中
        for(int num : nums){
            set.add(num);
        }

        int longestStreak = 0;
        //挨个数字检查
        for(int num : set){
            //从set集合中查是否有该比该数字小的数字,如果没有,作为开头开始继续往后找
            if(!set.contains(num - 1)){
                int currentNum = num;
                int currentStreak = 1;
                while(set.contains(currentNum + 1)){
                    currentNum += 1;
                    currentStreak += 1;
                }
                longestStreak = Math.max(longestStreak,currentStreak);
            }
        }
        return longestStreak;
    }
}

先挨个数字检查能作为头元素的数字,找到头元素后,开始找头元素连续的后续元素。

相关推荐
fengenrong8 分钟前
20260429
c++·算法
南宫萧幕10 分钟前
Python与Simulink联合仿真:基于DQN的HEV能量管理策略建模与全链路排雷实战
开发语言·人工智能·python·算法·机器学习·matlab·控制
apollowing25 分钟前
启发式算法WebApp实验室:从搜索策略到群体智能的能力进阶(优)
算法·启发式算法·web app
Chat_zhanggong3451 小时前
主推NT98336BG作用有哪些?
嵌入式硬件·算法
Run_Teenage2 小时前
算法:线段树
算法
Westward-sun.2 小时前
YOLOv2算法全方位解析:从BatchNorm到聚类先验框的九大改进
算法·yolo·聚类
扶苏xw2 小时前
【离散化算法】
算法
码之气三段.2 小时前
Codeforces Round 1095 (Div. 2) 补题
算法
6Hzlia2 小时前
【Hot 100 刷题计划】 LeetCode 189. 轮转数组 | C++ 三次反转经典魔法 (O(1) 空间)
c++·算法·leetcode
wuweijianlove2 小时前
算法可扩展性建模与渐进性能分析的技术7
算法