1 Star 0 Fork 0

xiangxiang/LeetCode-NOTES

加入 Gitee
与超过 1200万 开发者一起发现、参与优秀开源项目,私有仓库也完全免费 :)
免费加入
文件
克隆/下载
solution.cpp 1.20 KB
一键复制 编辑 原始数据 按行查看 历史
默然 提交于 7年前 . update all algorithms.
class Solution
{
public:
int longestConsecutive(vector<int> &num)
{
map<int, int> hmap;
hmap.clear();
int n = num.size();
for(int i=0; i<n; i++)
{
hmap.insert(pair<int, int>(num[i], i));
}
int ans=0, cnt=0;
map<int, int>::iterator it;
for(int i=0; i<num.size(); i++)
{
int cur = num[i];
it = hmap.find(num[i]);
cnt++;
if(it!=hmap.end())
{
map<int, int>::iterator iter;
while(1)
{
iter = hmap.find(++cur);
if(iter==hmap.end())
break;
cnt++;
hmap.erase(iter);
}
cur=num[i];
while(1)
{
iter = hmap.find(--cur);
if(iter==hmap.end())
break;
cnt++;
hmap.erase(iter);
}
if(ans<cnt)
ans = cnt;
cnt=0;
}
cnt=0;
}
return ans;
}
};
Loading...
马建仓 AI 助手
尝试更多
代码解读
代码找茬
代码优化
1
https://gitee.com/xiangxiang920/LeetCode-NOTES.git
git@gitee.com:xiangxiang920/LeetCode-NOTES.git
xiangxiang920
LeetCode-NOTES
LeetCode-NOTES
master

搜索帮助