Longest Consecutive Sequence

题目
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.

答案

class Solution {
    public int longestConsecutive(int[] nums) {
        if(nums.length == 0) return 0;
        int max = 1;
        HashSet<Integer> set = new HashSet<Integer>();
        for(int num : nums) set.add(num);
        for(int sample : nums) {
            if(!set.contains(sample)) continue;
            int left = sample , right = sample;
            while(set.contains(--left)) set.remove(left);
            while(set.contains(++right)) set.remove(right);
            max = Math.max((right - 1) - (left + 1) + 1, max);
        }
        return max;
    }
}
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容