博客
关于我
最长的连续元素序列长度(哈希表)
阅读量:368 次
发布时间:2019-03-04

本文共 1093 字,大约阅读时间需要 3 分钟。

题目描述:给定一个无序的整数类型数组,求最长的连续元素序列的长度。例如:数组为[1000, 4, 2000, 1, 3, 2],最长的连续元素序列为[1, 2, 3, 4],返回这个序列的长度:4。你需要给出时间复杂度在O(n)之内的算法。

思路:为了找到最长的连续整数序列,可以使用哈希表来记录出现过的数字。具体步骤如下:

  • 初始化一个哈希表(unordered_set)来存储数组中的数字。
  • 遍历数组中的每个数字。
  • 对于每个数字,检查其左边和右边是否存在于哈希表中。如果左边的数字存在,递减左边的数字并增加计数器,直到无法再找到左边的数字为止。
  • 同样地,检查右边的数字是否存在,递增右边的数字并增加计数器。
  • 每次找到一个更长的序列时,更新最长序列的长度。
  • 处理完一个数字后,将其从哈希表中删除,以避免重复处理。
  • 代码实现:

    #include 
    #include
    using namespace std;int longestConsecutive(vector
    num) { unordered_set
    seen; int max_len = 0; for (int num : num) { int current = num; int len = 1; // 检查左边的数字 while (seen.count(current - 1) > 0) { seen.erase(current - 1); len++; current--; } // 检查右边的数字 while (seen.count(current + 1) > 0) { seen.erase(current + 1); len++; current++; } if (len > max_len) { max_len = len; } } return max_len;}

    这个方法的时间复杂度是O(n),因为每个元素最多被处理两次(一次作为左边,一次作为右边),而哈希表的操作都是O(1)的时间复杂度。

    转载地址:http://yfdg.baihongyu.com/

    你可能感兴趣的文章
    Netty 异步任务调度与异步线程池
    查看>>
    Netty中集成Protobuf实现Java对象数据传递
    查看>>
    Netty事件注册机制深入解析
    查看>>
    Netty原理分析及实战(四)-客户端与服务端双向通信
    查看>>
    Netty客户端断线重连实现及问题思考
    查看>>
    Netty工作笔记0006---NIO的Buffer说明
    查看>>
    Netty工作笔记0007---NIO的三大核心组件关系
    查看>>
    Netty工作笔记0011---Channel应用案例2
    查看>>
    Netty工作笔记0013---Channel应用案例4Copy图片
    查看>>
    Netty工作笔记0014---Buffer类型化和只读
    查看>>
    Netty工作笔记0020---Selectionkey在NIO体系
    查看>>
    Vue踩坑笔记 - 关于vue静态资源引入的问题
    查看>>
    Netty工作笔记0025---SocketChannel API
    查看>>
    Netty工作笔记0027---NIO 网络编程应用--群聊系统2--服务器编写2
    查看>>
    Netty工作笔记0050---Netty核心模块1
    查看>>
    Netty工作笔记0057---Netty群聊系统服务端
    查看>>
    Netty工作笔记0060---Tcp长连接和短连接_Http长连接和短连接_UDP长连接和短连接
    查看>>
    Netty工作笔记0063---WebSocket长连接开发2
    查看>>
    Netty工作笔记0070---Protobuf使用案例Codec使用
    查看>>
    Netty工作笔记0077---handler链调用机制实例4
    查看>>