LeetCode【128】最长连续序列

题目:

分析:

1、最长连续序列的长度为 y-x+1,如1-4:4-1+1 = 4

2、不要被这里的On误导,不敢使用双层循环

3、只要找到最小的数值,并由此开始计算,不产生重复计算,则为On

代码:

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

        int max = 0;
        for (int i = 0; i < nums.length; i++) {
            if (!set.contains(nums[i] - 1)) {
                int y = nums[i] + 1;
                while (set.contains(y)) {
                    y++;
                }
                max = Math.max(max, y-nums[i]);
            }
        }

        return max;
    }
相关推荐
Yzzz-F7 分钟前
牛客小白月赛127 E
算法
大锦终10 分钟前
递归回溯综合练习
c++·算法·深度优先
Keep__Fighting20 分钟前
【神经网络的训练策略选取】
人工智能·深度学习·神经网络·算法
码农水水24 分钟前
蚂蚁Java面试被问:混沌工程在分布式系统中的应用
java·linux·开发语言·面试·职场和发展·php
海边的Kurisu27 分钟前
苍穹外卖日记 | Day4 套餐模块
java·苍穹外卖
晚风吹长发30 分钟前
初步了解Linux中的动静态库及其制作和使用
linux·运维·服务器·数据结构·c++·后端·算法
sin_hielo30 分钟前
leetcode 3453(二分法)
算法
毕设源码-邱学长43 分钟前
【开题答辩全过程】以 走失儿童寻找平台为例,包含答辩的问题和答案
java
坚持不懈的大白1 小时前
Leetcode学习笔记
笔记·学习·leetcode
风之歌曲1 小时前
c++高精度模板
c++·算法·矩阵