type
status
date
slug
summary
tags
category
icon
password
题目:
给你一个整数数组 nums 和一个整数 k ,判断数组中是否存在两个 不同的索引 i 和 j ,满足 nums[i] == nums[j] 且 abs(i - j) <= k 。如果存在,返回 true ;否则,返回 false 。
来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/contains-duplicate-ii
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。
示例 1:
示例 2:
示例 3:
提示:
1 <= nums.length <= 105
109 <= nums[i] <= 109
0 <= k <= 105
思路:
- 对数组进行两重遍历,判断,暴力解法
代码:
结果:

image-20220128220921800
另一个思路:
- 从第二条件先开始
- 还是对数组遍历,但是在第二重循环的时候只对比,i前面的k+j个数据
- 在这个范围内有相等的那就返回true
- 循环结束,返回false
代码:
结果:

image-20220128221308039