`
cozilla
  • 浏览: 92141 次
  • 性别: Icon_minigender_1
  • 来自: 南京
社区版块
存档分类
最新评论

[LeetCode] Longest Consecutive Sequence

 
阅读更多
Longest Consecutive SequenceFeb 14

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.

因为有O(N)的限制。

因此用hash来搞。

 

 

class Solution {
public:
    int longestConsecutive(vector<int> &num) {
    unordered_map<int, int> hash;
    vector<bool> flag(num.size(), false);
    for (int i = 0; i < num.size(); ++i) {
        hash[num[i]] = i;
    }

    int maxlen = 1;
    int less = 0, more = 0;
    for (int i = 0; i < num.size(); ++i) {
        if (flag[i]) continue;
        int tmp = num[i];
        auto it = hash.find(--tmp);
        less = 0;
        while (it != hash.end()) {
            ++less;
            flag[it->second] = true;
            it = hash.find(--tmp);
        }
        tmp = num[i];
        auto it2 = hash.find(++tmp);
        more = 0;
        while (it2 != hash.end()) {
            ++more;
            flag[it2->second] = true;
            it2 = hash.find(++tmp);
        }
        tmp = less + more + 1;
        maxlen = maxlen > tmp ? maxlen : tmp;
    }
    return maxlen;
}
};

 

class Solution {
public:
    int longestConsecutive(vector<int> &num) {
        unordered_map<int, bool> m;
        int len = num.size();
        for (int i = 0; i < len; i++) {
            m[num[i]] = false;
        }
        
        int res = 0;
        for (int i = 0; i < len; i++) {
            if (m[num[i]]) continue;
            int low = num[i], high = num[i];
            while (m.count(low) != 0) m[low] = true, low--;
            while (m.count(high) != 0) m[high] = true, high++;
            int t = high - low - 1;
            if (t > res) res = t;
        }
        return res;
    }
};

 

0
0
分享到:
评论

相关推荐

    python-leetcode题解之128-Longest-Consecutive-Sequence

    python python_leetcode题解之128_Longest_Consecutive_Sequence

    js-leetcode题解之128-longest-consecutive-sequence.js

    javascript js_leetcode题解之128-longest-consecutive-sequence.js

    LeetCode题解(java语言实现).pdf

    * Longest Consecutive Sequence Java:该题目要求找到最长的连续序列,实现方法使用了哈希表和迭代算法。 * Search a 2D Matrix:该题目要求在二维矩阵中查找元素,实现方法使用了二分查找算法。 * Rotate Image:...

    2018年最新Google Onsite面经总结1

    Binary Tree Longest Consecutive Sequence等。这类题目通常要求读者使用树的各种操作来解决问题,例如树的遍历、查找、插入等操作。 4. 图类题目 图类题目是LeetCode原题中的一个复杂类题目,本文中涵盖了多个图...

    lrucacheleetcode-LeetCode:这个库用于总结leetcode中遇到的习题,期望按照数据结构和常用方法分成2类,进行总结,

    Consecutive Sequence 7 Two Sum Hash,夹逼均可 8 3Sum Hash法转换2sum 9 3Sum Closest Sort +夹逼法 10 4Sum Sort +夹逼法 11 Remove Element 12 Next Permutation 公式 13 Permutation Sequence 公式 14 Valid ...

    leetcode中文版

    2. **2.1.6 Longest Consecutive Sequence**:给定一个未排序的整数数组,找出其中最长连续序列的长度。 3. **2.1.7 Two Sum**:给定一个整数数组 nums 和一个目标值 target,请你在该数组中找出和为目标值的那两个...

    leetcode分类-Leetcode:Leetcode题解

    leetcode 分类 Leetcode代码题解 随缘刷题,选择性更新题解 LeetCode 94 144 145 ...longest-consecutive-sequence 最长连续序列: Leetcode 155 Min Stack 最小栈: LeetCode 773 滑动谜题: ......

    LeetCode最全代码

    # [LeetCode](https://leetcode.com/problemset/algorithms/) ![Language](https://img.shields.io/badge/language-Python%20%2F%20C++%2011-orange.svg) [![License]...

    python-leetcode面试题解之第128题最长连续序列-题解.zip

    LeetCode的第128题,名为"Longest Consecutive Sequence",要求找到给定无序整数数组中,最长的连续整数序列的长度。例如,对于输入数组 [100, 4, 200, 1, 3, 2],最长连续序列是 [1, 2, 3, 4],其长度为4。 首先,...

    leetcode正方体堆叠-TakeUforward-SDE_180:TakeUforward-SDE_180

    leetcode正方体收藏TakeUforward-SDE_180 要了解整个列表和其他内容,如项目、简历、如何进行面试……观看整个视频: 在以下位置找到展示位置系列: ...Consecutive Sequence Longest Subarray with 0 sum 给定

    lrucacheleetcode-leetcode:个人刷leetcode遇到的一些题汇总(golang)

    longest-consecutive-sequence max-area-of-island next-greater-element-ii serialize-and-deserialize-binary-tree subarray-sum-equals-k binary-tree-preorder-traversal n-queens-ii populating-next-right-...

    leetcode题库-leetcode:算法代码-JavaScript

    例如,"最长连续序列"(Longest Consecutive Sequence)题目的解决方案通常会用到哈希表来存储数组元素及其出现的次数,再结合深度优先搜索或广度优先搜索策略找出最长的连续序列。 3. 优化技巧:在解决LeetCode...

    leetcode:LeetCode练习

    5. **动态规划**:如“最长连续序列”(Longest Consecutive Sequence),要求找到一个无序整数数组中最长的连续子序列。 6. **回溯法**:如“全排列”(Permutations),要求列出所有可能的数组排列。 7. **堆和队列*...

    leetcode跳跃-leetcode:leetcode题解

    比如,“最长连续序列”(Longest Consecutive Sequence)要求找到给定无序整数数组中最长的连续序列长度,这涉及到哈希表和递归/迭代的巧妙结合。 LeetCode平台的开源特性意味着用户可以查看其他人的解决方案,...

    javalruleetcode-SDE-Problems:标准SDE问题列表

    leetcode SDE-问题 标准 SDE 问题列表 第一天:(数组) 日 问题陈述 解决方案 困难 使用的数据结构 使用的算法 时间复杂度 空间复杂度 补充阅读 在 N 个整数的数组中查找重复项 中等的 大批 不适用 上) O(1) 在不...

    leetcode-cpp刷题

    - **2.1.6 Longest Consecutive Sequence** - 找出数组中最长的连续子序列。 - 实现思路:可以使用哈希表存储每个元素及其连续状态,然后遍历数组找到最长的连续序列。 - **2.1.7 Two Sum** - 寻找数组中两个数...

    leetcode分类-leetcode:leetcode刷题

    4. **滑动窗口**:在数组中使用滑动窗口进行统计,如“最长连续序列”(Longest Consecutive Sequence)。 5. **数组分割**:根据特定条件将数组分割成多个子数组,如“分割数组的最大和”(MaxChunks ToSorted)。...

    leetcode卡-LeetCode-HashTable:此存储库包含HashTable探索卡中所有问题的解决方案

    5. **滑动窗口最大值/最小值**:例如“数组中的最长连续序列”(Longest Consecutive Sequence),哈希表可以帮助我们快速查询元素及其相邻元素的状态,从而找到最长连续序列。 6. **统计问题**:如“数组中出现...

    Leetcode:此回购包含Leetcode问题的解决方案

    此外,"Leetcode-main"可能还包含了其他挑战,如“最长连续序列”(Longest Consecutive Sequence)来演示如何使用集合进行有效的状态追踪,或者“最大子数组和”(Maximum Subarray)来展示动态规划的应用。每个问题的...

Global site tag (gtag.js) - Google Analytics