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;
    }
相关推荐
liliangcsdn2 小时前
探索和学习信任区域策略优化算法-TRPO
学习·算法
勇往直前plus3 小时前
从文件到屏幕:Python/java 字符编码、解码、文本处理的底层逻辑解析
java·开发语言·python
Mr YiRan7 小时前
C++面向对象继承与操作符重载
开发语言·c++·算法
Drifter_yh9 小时前
【黑马点评】Redisson 分布式锁核心原理剖析
java·数据库·redis·分布式·spring·缓存
莫寒清10 小时前
Spring MVC:@RequestParam 注解详解
java·spring·mvc
没有医保李先生11 小时前
字节对齐的总结
java·开发语言
蚊子码农11 小时前
算法题解记录--239滑动窗口最大值
数据结构·算法
liliangcsdn11 小时前
A3C算法从目标函数到梯度策略的探索
算法
陈天伟教授11 小时前
人工智能应用- 材料微观:06.GAN 三维重构
人工智能·神经网络·算法·机器学习·重构·推荐算法
liliangcsdn12 小时前
A3C强化学习算法的探索和学习
算法