查找数组中连续的数

Posted ranran1203

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了查找数组中连续的数相关的知识,希望对你有一定的参考价值。

Given an unsorted array of integers, find the length of the longest consecutive elements sequence.

For example,
Given[100, 4, 200, 1, 3, 2],
The longest consecutive elements sequence is[1, 2, 3, 4]. Return its length:4.

Your algorithm should run in O(n) complexity.

 

使用了一个map结构记录数据,每次对于num[i]在map中查找num[i]-1 ,num[i]+1两边的元素,找到就删了,记录最大长度

 

class Solution {
public:
int longestConsecutive(vector<int> &num) {
  int max=0;
  int count=1;
  map<int,int>mp;
  for(int i=0;i<num.size();i++)
  {
    mp.insert(pair<int,int>(num[i],1));
  }
  for(int i=0;i<num.size();i++)
  {
    if(mp.find(num[i])==mp.end())
      continue;
    int cur=num[i];
    while(1)
    {
    if(mp.find(--cur)!=mp.end())
    {
      count++;
      mp.erase(cur);
    }
    else
      break;

    }
    cur=num[i];
    while(1)
    {
    if(mp.find(++cur)!=mp.end())
    {
    count++;
    mp.erase(cur);
    }
    else
      break;
  }
  if(max<count)
    max=count;
  count=1;
}
return max;
}
};

以上是关于查找数组中连续的数的主要内容,如果未能解决你的问题,请参考以下文章

LeetCode 128 最长连续序列

C++ 查找容器中两个连续且相等的数

java求数组中,某个值连续出现次数最多的数的次数

滴滴笔试1.连续数组的最大和 2.找出数组中第K大的数

在数组中查找连续范围

在数组中查找具有最小差异和连续元素的 2 个子集