zoukankan      html  css  js  c++  java
  • 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;
        }
    }
    
  • 相关阅读:
    第一次作业(2)
    第0次作业(2)
    最后一次作业—总结报告
    第八次作业
    第七周作业
    第六周作业
    第四周作业
    第4次作业
    2018c语言第3次作业
    2018c语言第2次作业
  • 原文地址:https://www.cnblogs.com/xkf97/p/13215895.html
Copyright © 2011-2022 走看看