LeetCode题练习与总结:最长连续序列--128

一、题目描述

给定一个未排序的整数数组 nums ,找出数字连续的最长序列(不要求序列元素在原数组中连续)的长度。

请你设计并实现时间复杂度为 O(n) 的算法解决此问题。

示例 1:

输入:nums = [100,4,200,1,3,2]
输出:4
解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。

示例 2:

输入:nums = [0,3,7,2,5,8,4,6,0,1]
输出:9

提示:

  • 0 <= nums.length <= 10^5
  • -10^9 <= nums[i] <= 10^9

二、解题思路

要设计一个时间复杂度为O(n)的算法,我们可以使用哈希集合(HashSet)来存储数组中的所有数字。然后,我们可以遍历数组中的每个数字,对于每个数字,我们检查其是否为某个连续序列的最小数字。如果是,我们就更新最长连续序列的长度。

算法步骤如下:

  1. 将数组中的所有数字添加到哈希集合中。
  2. 遍历数组中的每个数字,对于每个数字,如果其在哈希集合中且其前一个数字不在哈希集合中,那么这个数字就是某个连续序列的最小数字。
  3. 对于每个这样的最小数字,我们可以计算以其为起点的连续序列的长度,并更新最长连续序列的长度。

三、具体代码

import java.util.HashSet;
import java.util.Set;

public class Solution {
    public int longestConsecutive(int[] nums) {
        if (nums == null || nums.length == 0) {
            return 0;
        }

        Set<Integer> numSet = new HashSet<>();
        for (int num : nums) {
            numSet.add(num);
        }

        int longestStreak = 0;
        for (int num : nums) {
            if (!numSet.contains(num - 1)) {
                int currentNum = num;
                int currentStreak = 1;

                while (numSet.contains(currentNum + 1)) {
                    currentNum++;
                    currentStreak++;
                }

                longestStreak = Math.max(longestStreak, currentStreak);
            }
        }

        return longestStreak;
    }
}

四、时间复杂度和空间复杂度

1. 时间复杂度
  • 将数组中的所有数字添加到哈希集合中:这一步的时间复杂度是O(n),因为我们需要遍历数组中的每个数字一次,并将它们添加到哈希集合中。哈希集合的添加操作通常是O(1)的时间复杂度。
  • 遍历数组中的每个数字,并计算以它们为起点的连续序列的长度:这一步的时间复杂度也是O(n),因为我们需要遍历数组中的每个数字一次。对于每个数字,我们可能会计算以其为起点的连续序列的长度,这个计算过程在最坏情况下会遍历整个数组,但是由于哈希集合的存在,每个数字只会被计算一次。因此,这一步的整体时间复杂度仍然是O(n)。
  • 综上所述,整个算法的时间复杂度是O(n)。
2. 空间复杂度
  • 哈希集合:我们需要一个哈希集合来存储数组中的所有数字,因此空间复杂度是O(n),其中n是数组中数字的数量。
  • 综上所述,整个算法的空间复杂度是O(n)。

五、总结知识点

  1. 哈希集合(HashSet):用于存储数组中的所有数字,以便快速判断一个数字是否存在于数组中。哈希集合的特点是添加和查找操作的平均时间复杂度为O(1)。

  2. 数组遍历:使用for-each循环遍历数组中的每个元素。

  3. 条件语句:使用if语句来检查数字是否为某个连续序列的最小数字。

  4. 循环结构:使用while循环来找到以某个数字为起点的最长连续序列。

  5. 数学运算:使用加减法来生成连续序列中的下一个数字,并使用Math.max函数来更新最长连续序列的长度。

  6. 函数定义:定义了一个名为longestConsecutive的公共方法,该方法接受一个整数数组作为参数,并返回一个整数作为结果。

  7. 异常处理:检查输入数组是否为null或长度为0,如果是,则直接返回0,这是一种简单的异常处理方式。

  8. 变量声明和赋值:声明了多个变量来存储当前的数字、当前的连续序列长度和最长的连续序列长度。

  9. 算法设计:整个代码的核心是设计了一个时间复杂度为O(n)的算法来找到最长的连续序列,这涉及到对问题的分析和解决方案的设计。

  10. 代码结构:代码遵循了良好的结构,先处理特殊情况,然后是主要逻辑,最后返回结果。

以上就是解决这个问题的详细步骤,希望能够为各位提供启发和帮助。

相关推荐

  1. LeetCode练习总结连续序列--128

    2024-06-16 14:30:04       34 阅读
  2. LeetCode每日刷.09(128.连续序列)

    2024-06-16 14:30:04       53 阅读
  3. LeetCode-热100:128.连续序列

    2024-06-16 14:30:04       43 阅读
  4. Leetcode128.连续序列

    2024-06-16 14:30:04       52 阅读
  5. leetCode 128.连续序列

    2024-06-16 14:30:04       57 阅读
  6. LeetCode 128 连续序列

    2024-06-16 14:30:04       40 阅读

最近更新

  1. docker php8.1+nginx base 镜像 dockerfile 配置

    2024-06-16 14:30:04       98 阅读
  2. Could not load dynamic library ‘cudart64_100.dll‘

    2024-06-16 14:30:04       106 阅读
  3. 在Django里面运行非项目文件

    2024-06-16 14:30:04       87 阅读
  4. Python语言-面向对象

    2024-06-16 14:30:04       96 阅读

热门阅读

  1. 前端 CSS 经典:好用的 CSS 选择器

    2024-06-16 14:30:04       31 阅读
  2. 免费外链网站大全,助力新站收录加速

    2024-06-16 14:30:04       33 阅读
  3. (60)MOS管专题--->(15)MOS场效应管

    2024-06-16 14:30:04       49 阅读
  4. 25.梯度消失和梯度爆炸

    2024-06-16 14:30:04       23 阅读
  5. yocto根文件系统如何配置静态IP地址

    2024-06-16 14:30:04       36 阅读
  6. web前端网上私活:探索、挑战与成长的独特之旅

    2024-06-16 14:30:04       29 阅读
  7. Web前端网页滚动效果:深度解析与创意实践

    2024-06-16 14:30:04       32 阅读
  8. c++题目_第K小的数(进阶)

    2024-06-16 14:30:04       32 阅读
  9. [AIGC] 深入浅出 Python中的`enumerate`函数

    2024-06-16 14:30:04       30 阅读