[HOT100]每日一练------最长连续序列

题目链接

128. 最长连续序列 - 力扣(LeetCode)

思路

主要就是找连续子序列开始的起点 ,然后慢慢找最长的长度。由于题目第三个列子我们可以知道,重复的数字不计入长度,因此我们可以先用set去重,再找每一个子序列的起点,即**set中不包含num - 1,**再看以这个数为起点的最长连续序列长度为多少,与之前保存的结果比较

代码

java 复制代码
class Solution {
    //找连续起点
    public int longestConsecutive(int[] nums) {
        int res = 0;
        HashSet<Integer> set = new HashSet<>();
        for (int num : nums)
            set.add(num);
        for (int num : set) {
            //找到起点
            if (!set.contains(num - 1)) {
                int currentNum = num;
                int currentLength = 1;
                while (set.contains(currentNum + 1)) {
                    currentNum++;
                    currentLength++;
                }
                res = Math.max(res, currentLength);
            }
        }
        return res;
    }
}
相关推荐
csdn_aspnet2 小时前
PHP 算法 LeetCode 编号 70 - 爬楼梯
算法·leetcode·php
沈浩(种子思维作者)2 小时前
没有错误,正确将一文不值
人工智能·python·算法·量子计算
x_xbx2 小时前
LeetCode:5. 最长回文子串
算法·leetcode·职场和发展
快手技术2 小时前
免费报名|生成式推荐技术如何实现体系化演进?快手技术沙龙第四期开启!
算法
初夏睡觉2 小时前
数字截断求和 题解
算法
AZaLEan__2 小时前
多源 BFS
java·开发语言·算法
smith成长之旅2 小时前
07 | Mem0 框架分析:三路信号融合——语义 + BM25 + Entity Boost 的混合检索
python·算法
wabs6662 小时前
关于贪心算法章节的【有两个维度问题】的自我总结
算法·贪心算法
未若君雅裁3 小时前
算法复杂度与数据结构:Java 集合篇的第一块基石
java·数据结构·算法