查找数组中连续的数
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;
}
};
以上是关于查找数组中连续的数的主要内容,如果未能解决你的问题,请参考以下文章