力扣hot100:最长连续序列

题目描述:

思路分析:

对于 nums 中的元素 x,以 x 为起点,不断查找下一个数 x+1,x+2,⋯ 是否在 nums 中,并统计序列的长度。

由于需要不断查找元素是否在数组中,可以把数组中的元素存到哈希表中,这样查找的效率会变成O(1),于是首先定义一个哈希表,把数组中的元素存入进去,在遍历哈希表的数,不断尝试找到最大连续字数组中最小的数组和最大的数字,两数之差加1就是最大连续子数组的长度。

代码:

java 复制代码
class Solution {
    public int longestConsecutive(int[] nums) {
        int ans=0;
        Set<Integer> a=new HashSet();
        for(int b:nums){
            a.add(b);
        }
        for(int b:a){
            int n=b;
            if(a.contains(n-1)){
                continue;
            }
            while(a.contains(n+1)){
                n++;
            }
            ans=Math.max(ans,n-b+1);
        }
        return ans;
    }
}
相关推荐
爱学习的小仙女!7 小时前
顺序表定义、特点和基本操作(含C代码详细讲解)及时间复杂度
数据结构·算法
芥子沫7 小时前
《人工智能基础》[算法篇5]:SVM算法解析
人工智能·算法·机器学习·支持向量机·svm
BigerBang8 小时前
LoRA 全方位指南:从底层原理到 Qwen-Image-Edit 实战
人工智能·pytorch·深度学习·算法
passxgx8 小时前
11.3 迭代法和预条件子
线性代数·算法·矩阵
X在敲AI代码8 小时前
【无标题】
算法·leetcode·职场和发展
bubiyoushang8888 小时前
NSGA-II 带精英策略的双目标遗传算法
算法
qq_430855888 小时前
线代第二章矩阵第八节逆矩阵、解矩阵方程
线性代数·算法·矩阵
月明长歌8 小时前
【码道初阶】Leetcode136:只出现一次的数字:异或一把梭 vs HashMap 计数(两种解法完整复盘)
java·数据结构·算法·leetcode·哈希算法
Swift社区8 小时前
LeetCode 456 - 132 模式
java·算法·leetcode
LYFlied8 小时前
【每日算法】LeetCode 152. 乘积最大子数组(动态规划)
前端·算法·leetcode·动态规划