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;
}
}