标签:java leetcode containsduplicateii
题目:
Given an array of integers and an integer k,
find out whether there there are two distinct indices i and j in
the array such that nums[i] = nums[j] and
the difference between i and j is
at most k.
解题:
第一种办法:
最直接用双重循环进行判断,o(n^2)复杂度不能通过
第二种办法:
用哈希表,key存数组元素值,value存元素对应的索引,每来一个元素进行判断如果之前没有存过则存进去,如果之前有存则取出之前那个元素的索引值判断是否小于K,小于k返回true,不小于则存进去覆盖之前的那个。
代码:
public static boolean containsNearbyDuplicate(int[] nums, int k) { int length=nums.length; Hashtable<Integer, Integer> hashtable=new Hashtable<>(); for(int i=0;i<length;i++) { if(hashtable.get(nums[i])==null) { hashtable.put(nums[i], i); } else { int k1=hashtable.get(nums[i]); if(i-k1<=k) return true; else { hashtable.put(nums[i], i); } } } return false; }
代码:
public static boolean containsNearbyDuplicate2(int[] nums, int k) {
int length=nums.length;
Set<Integer> set=new HashSet<>();
for(int i=0;i<length;i++)
{
if(i<k+1)
{
set.add(nums[i]);
if(set.size()<i+1)
return true;
}
else {
set.remove(nums[i-k-1]);
set.add(nums[i]);
if(set.size()<k+1)
return true;
}
}
return false;
}
版权声明:本文为博主原创文章,未经博主允许不得转载。
LeetCode219 ContainsDuplicateII java题解
标签:java leetcode containsduplicateii
原文地址:http://blog.csdn.net/u012249528/article/details/46729453