【力扣 Hot100 | 第六天】4.21(最长连续序列)

在这里插入图片描述

文章目录

  • 10.最长连续序列
    • 10.1题目
    • 10.2解法:哈希法
      • 10.2.1哈希思路
      • 10.2.2代码实现

10.最长连续序列

10.1题目

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

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

  • 示例一:
输入:nums = [100,4,200,1,3,2]
输出:4
解释:最长数字连续序列是 [1, 2, 3, 4]。它的长度为 4。
  • 示例二:
输入:nums = [0,3,7,2,5,8,4,6,0,1]
输出:9

10.2解法:哈希法

10.2.1哈希思路

  • 题目要求时间复杂度为O(n)
  • 核心:一次遍历,每个数都判断一次这个数是不是连续序列的开头那个数
    • 用哈希表查找这个数前面一个数是否存在,即num-1在序列中是否存在。存在那这个数肯定不是开头,直接跳过
    • 因此只需要对每个开头的数进行循环,直到这个序列不再连续,因此复杂度是O(n)。
  • 举例:[100,4,200,1,3,4,2] 去重后的哈希序列为:
    [100,4,200,1,3,2]
    按照上面逻辑进行判断:
    • 元素100是开头,因为没有99,且以100开头的序列长度为1
    • 元素4不是开头,因为有3存在,过,
    • 元素200是开头,因为没有199,且以200开头的序列长度为1
    • 元素1是开头,因为没有0,且以1开头的序列长度为4,因为依次累加,2,3,4都存在。
    • 元素3不是开头,因为2存在,过,
    • 元素2不是开头,因为1存在,过。

10.2.2代码实现

	public int longestConsecutive(int[] nums) {if(nums.length==0){return 0;}int res=Integer.MIN_VALUE;Set<Integer> set=new HashSet<>();for(int num:nums){set.add(num);}//1、遍历整个nums数组for(int num:nums){//2、判断 num 是否为有序序列的第一个元素if(set.contains(num-1)==false){//3、num为第一个元素int max=1;while(set.contains(num+1)){num++;max++;}//4、更新最长连续序列长度res=Math.max(res,max);}}return res;}

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/641667.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

HSB矩形调色板设计和计算方法

HSB矩形调色板设计和计算方法 RGB调色板绘制较容易&#xff0c;HSB调色板较难绘制&#xff0c;前些天发文介绍了几个矩形样例的绘制方法&#xff0c;今介绍矩形的HSB调色板的设计方法和H,S,B值的计算方法&#xff0c;好东西必须与大家分享。 此文介绍HSB调色板和选色条的绘制方…

idea上传项目到gitee(码云)

1、打开码云&#xff0c;新建仓库 2、创建 3、这就是创建成功的页面 4、复制仓库地址&#xff0c;后面需要用到 2、打开我们的项目&#xff1a;例如我现在的项目 1、idea创建git仓库 2、选择我们项目文件夹的目录 3、查看文件是否变色&#xff0c;变色表示成功了 4、添加到缓…

【Java】Java基础 使用集合实现斗地主分牌

&#x1f4dd;个人主页&#xff1a;哈__ 期待您的关注 今天使用集合TreeSet来实现一个斗地主的分牌流程。 TreeSet集合的一个特点就是 元素有序&#xff0c;这样就方便我们分的牌自动排序。 0.思路 1.创建玩家手牌集合 我们到时候分的牌都存储在这里&#xff0c;但你可能会…

Web前端安全问题分类综合以及XSS、CSRF、SQL注入、DoS/DDoS攻击、会话劫持、点击劫持等详解,增强生产安全意识

前端安全问题是指发生在浏览器、单页面应用、Web页面等前端环境中的各类安全隐患。Web前端作为与用户直接交互的界面&#xff0c;其安全性问题直接关系到用户体验和数据安全。近年来&#xff0c;随着前端技术的快速发展&#xff0c;Web前端安全问题也日益凸显。因此&#xff0c…

山海鲸电力看板:运维数据一目了然

在信息化高速发展的今天&#xff0c;电力行业的运维管理也迎来了前所未有的变革。山海鲸可视化智慧电力运维可视化看板&#xff0c;以其独特的数据整合能力和直观的可视化效果&#xff0c;成为了电力行业运维管理的得力助手&#xff0c;为电力的稳定运行提供了强大的技术支撑。…

[图解]软件开发中的糊涂用语-05-非功能需求算不算糊涂用语

0 00:00:00,350 --> 00:00:02,997 今天呢&#xff0c;我们来看一个用语 1 00:00:02,997 --> 00:00:04,100 非功能需求 2 00:00:04,620 --> 00:00:07,060 这个算不算糊涂用语 3 00:00:09,890 --> 00:00:13,000 这是来自一个学员的问题 4 00:00:13,000 --> 00…

详解Mixtral-8x7B背后的MoE!

高端的模型往往只需最朴素的发布方式。 这个来自欧洲的大模型团队在12月8日以一条磁力链接的方式发布了Mixtral-8x7B,这是一种具有开放权重的**「高质量稀疏专家混合模型」**(SMoE)。 该模型在大多数基准测试中都优于Llama2-70B,相比之下推理速度快了6倍,同时在大多数标准基…

内存泄漏详解

一、什么是内存泄漏&#xff1f;二、内存泄漏的原因三、内存泄漏的影响四、如何检测和解决内存泄漏&#xff1f;五、总结 一、什么是内存泄漏&#xff1f; 内存泄漏指的是程序中已分配的内存没有被正确释放&#xff0c;导致这部分内存无法被再次利用&#xff0c;最终导致内存资…

OLED透明屏的制造过程是怎样的?

OLED透明屏的制造过程是一个复杂且精细的工艺&#xff0c;它涉及多个关键步骤以确保最终的显示效果和透明度。以下是OLED透明屏制造过程的主要步骤&#xff1a; 基板准备&#xff1a;制造过程始于对基板的准备。基板通常是玻璃或塑料材料&#xff0c;需要进行清洗和表面处理&am…

echerts饼图分割操作

在饼图制作中遇到了一个难点就是饼图中间是分散的 试了很多方法&#xff0c;最后选择了给每个值中间再加一节的处理方式&#xff0c;并把颜色设置为透明就能达到相同效果。 处理后的样式&#xff1a; 代码&#xff1a; let list this.data.list;/饼图内部展示数据// let _t…

金融风控信用评分卡建模(Kaggle give me credit数据集)

1 数据预处理数据 数据来源于Kaggle的Give Me Some Credit&#xff0c;包括25万条个人财务情况的样本数据 1.1 导包读数据 import pandas as pd import numpy as np import matplotlib.pyplot as plt from sklearn.ensemble import RandomForestRegressor import seaborn as …

Midjourney与waifu2x双剑合璧:完美打造超高清动漫图像

在追求完美的动漫图像时&#xff0c;质量和分辨率是两个关键因素。Midjourney&#xff08;一个神秘而强大的AI图像生成工具&#xff09;与waifu2x&#xff08;一个专门用于放大动漫风格图像的AI工具&#xff09;的结合使得创造超高清的动漫图像变得触手可及。本文将引导您如何使…