LeetCode 128

128. 最长连续序列

用哈希表记录当前数为端点时的最大区间长度

遍历数组,如果当前数在哈希表中出现过,则跳过

如果当前数未出现,则取相邻的两数在哈希表中的值,left 和 right,当前数所在的区间长度为left + right +1,然后将该值填入端点处。

class Solution {
    public int longestConsecutive(int[] nums) {
        HashMap<Integer,Integer> hash = new HashMap<>();
        int max_length = 0;
        for(int i = 0 ; i < nums.length ; i ++ ){
            if(hash.containsKey(nums[i])) continue;
            int left = hash.getOrDefault(nums[i]-1,0);
            int right = hash.getOrDefault(nums[i]+1,0);
            int cur_length = left + right + 1;
            hash.put(nums[i],-1);//填入-1只是为了表示当前数在哈希表中出现过
            if(cur_length>max_length) max_length = cur_length;
          //在端点处填入区间长度
            hash.put(nums[i]+right,cur_length);
            hash.put(nums[i]-left,cur_length);
        }
        return max_length;
    }
}
posted @ 2020-06-30 20:51  咸鱼不闲咋整啊  阅读(101)  评论(0编辑  收藏  举报