精品专栏
- 常用经典数据结构和算法 ★★★★★
- 夯实Java并发基础大汇总 ★★★★★
- SpringCloud微服务实战 ★★★★
- 2018年所有精华文章汇总 ★★★★★
阅读文本大概需要 3 分钟。
我给大家分享 LeetCode 算法题,主要都是挑选那些很可能在面试中出现的题,或者可能出现类似的题,多看看这些题至少能够在面试中不那么被动。
上次给大家分享过一次LeetCode 算法 | 数组中有重复元素吗?今天给大家分享的 LeetCode 算法题还和数组中重复元素相关,一起来看一看。
题目:
给定一个整数数组和一个整数 k,判断数组中是否存在两个不同的索引 i 和 j,使得 nums [i] = nums [j],并且 i 和 j 的差的绝对值最大为 k。
示例1:
输入: nums = [1,2,3,1], k = 3
输出: true
示例2:
输入: nums = [1,0,1,1], k = 1
输出: true
示例3:
输入: nums = [1,2,3,1,2,3], k = 2
输出: false
这道题,分享两种方法给大家。
1. 直接法
看到这道题,很多人的第一反应就是我挨个比较不就行了吗?首先都跟第一个元素比较,然后再第二轮,将后面的元素和第二个比较,在这过程中,只要满足题目要求,就返回 true,看下代码:
public boolean containsNearbyDuplicate(int[] nums, int k) {
for (int i = 0; i < nums.length; i++) {
for (int j = i + 1; j < nums.length; j++) {
if (nums[i] == nums[j]) {
if (j - i <= k) {
return true;
}
}
}
}
return false;
}
这种方式时间复杂度会很高,因为有两层循环,那么我们可否考虑不用两层循环呢?答案是肯定的。
2. 使用 HashMap
为什么可以使用 HashMap 呢?还记得之前我分享的一篇文章吗?LeetCode 算法 | 两数之和不简单啊,这里面有 HashMap 来处理和的问题,我在这也套用一下。
使用 num[i] 作为 key,索引的位置 i 作为 value,每次根据 num[i] 的值来获取 i,并计算间隔,如下:
public boolean containsNearbyDuplicate(int[] nums, int k) {
Map<Integer, Integer> map = new HashMap<>();
int inter = 0;
for(int i = 0; i < nums.length; i++) {
if(map.containsKey(nums[i])) {
inter = i - map.get(nums[i]);
if(inter <= k) {
return true;
}
// 更新key为nums[i]的位置
map.put(nums[i], i);
} else {
map.put(nums[i], i);
}
}
return false;
}
所以我们巧妙的运用 HashMap 可以将算法复杂度降低到 O(n)。
OK,这道算法题,就分享这么多,希望能对大家有所启发。如果你有其他思路,也欢迎留言。我建了个 LeetCode 算法交流群,大家在下方可以加我微信,我拉你进群,共同学习交流。
END
推 荐 阅 读
LeetCode 算法 | 两数之和不简单啊 LeetCode 算法 | 如何拆分数组? LeetCode 算法 | 数组中有重复元素吗? LeetCode 算法 | 如何排列硬币?
扫描我的二维码
备注:算法