day25(12.5)——leetcode面试经典150

128. 最长连续序列

128. 最长连续序列

哇去,到底是哪个天才这么聪明,居然想到了只有当它是起始序列头的时候才开始while,牛,这样确保了一个元素最多遍历两次。

题目:

题解:

这是我最开始的代码,时间复杂度为O(nlog(n)),于是我想优化,所以才发现了下面的解法

java 复制代码
class Solution {
    public int longestConsecutive(int[] nums) {
        Map<Integer,Integer> map = new HashMap<>();
        int max = 0;
        Arrays.sort(nums);
        for(int i=0;i<nums.length;i++) {
            if(map.containsKey(nums[i]-1)&&!map.containsKey(nums[i])) {
                map.put(nums[i], map.get(nums[i]-1)+1);
            }
            else if(!map.containsKey(nums[i]-1)&&!map.containsKey(nums[i])) {
                map.put(nums[i], 1);
            }
            max = Math.max(max,map.get(nums[i]));
        }
        return max;
    }
}
java 复制代码
class Solution {
    public int longestConsecutive(int[] nums) {
        Set<Integer> set = new HashSet<>();
        int max = 0;
        for(int i=0;i<nums.length;i++) {
            set.add(nums[i]);
        }
        for(Integer x:set) {
            //只有当x-1不存在,即是连续序列的首位是才进行遍历统计
            //保证每个元素最多遍历两次
            if(!set.contains(x-1)) {
                int len = 0;
                while(set.contains(x)) {
                    len++;
                    x++;
                }
                max = Math.max(max,len);
            }
        }
        return max;
    }
}
相关推荐
晓13138 分钟前
第二章 【C语言篇:入门】 C 语言基础入门
c语言·算法
yong999020 分钟前
MATLAB面波频散曲线反演程序
开发语言·算法·matlab
JicasdC123asd34 分钟前
【工业检测】基于YOLO13-C3k2-EIEM的铸造缺陷检测与分类系统_1
人工智能·算法·分类
Not Dr.Wang4221 小时前
自动控制系统稳定性研究及判据分析
算法
VT.馒头1 小时前
【力扣】2722. 根据 ID 合并两个数组
javascript·算法·leetcode·职场和发展·typescript
ffqws_1 小时前
A*算法:P5507 机关 题解
算法
执着2592 小时前
力扣hot100 - 108、将有序数组转换为二叉搜索树
算法·leetcode·职场和发展
2501_901147832 小时前
学习笔记:单调递增数字求解的迭代优化与工程实践
linux·服务器·笔记·学习·算法
AI科技星2 小时前
张祥前统一场论核心场方程的经典验证-基于电子与质子的求导溯源及力的精确计算
线性代数·算法·机器学习·矩阵·概率论
kebijuelun2 小时前
ERNIE 5.0:统一自回归多模态与弹性训练
人工智能·算法·语言模型·transformer