LeetCode 219. Contains Duplicate II
2016-04-12 20:43
459 查看
Given an array of integers and an integer k, find out whether 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.
给定一个整型数组和一个整数k,找出数组中是否有两个相等的整数,下标各不相同并且相差最大为k
看到这道题我首先想到的就是滑动窗口法,判断一个大小为k的窗口内的数字是否有重复的,没有再移动到下一个窗口。
于是这个方法分为几个步骤:
1. 从第一个数nums[0]开始向后往窗口添加数。窗口的整数数量不足k+1则扩大到k+1大小为止,这样第一个数和最后一个数的下标差刚好为k。
2. 对新添加进窗口的数判断HashSet中是否已经存在,是则直接返回true,否则添加到HashSet中。这里还有很多其他方法,比如用一个数组或者map对出现过的数进行标记等。
3. 窗口向后移一格,需要将被移出窗口的最左边的数从HashSet中移除。
4. 重复步骤2直到窗口移到了数组末尾。
5. 没有下标差小于等于k的相等整数的情况,最后返回false
代码如下
给定一个整型数组和一个整数k,找出数组中是否有两个相等的整数,下标各不相同并且相差最大为k
看到这道题我首先想到的就是滑动窗口法,判断一个大小为k的窗口内的数字是否有重复的,没有再移动到下一个窗口。
于是这个方法分为几个步骤:
1. 从第一个数nums[0]开始向后往窗口添加数。窗口的整数数量不足k+1则扩大到k+1大小为止,这样第一个数和最后一个数的下标差刚好为k。
2. 对新添加进窗口的数判断HashSet中是否已经存在,是则直接返回true,否则添加到HashSet中。这里还有很多其他方法,比如用一个数组或者map对出现过的数进行标记等。
3. 窗口向后移一格,需要将被移出窗口的最左边的数从HashSet中移除。
4. 重复步骤2直到窗口移到了数组末尾。
5. 没有下标差小于等于k的相等整数的情况,最后返回false
代码如下
public class Solution { public boolean containsNearbyDuplicate(int[] nums, int k) { k = k + 1; HashSet<Integer>distSet = new HashSet<Integer>(); for(int i = 0; i < nums.length;i++) { if(i >= k) { distSet(nums[i-k]); } if(distSet(nums[i])) return true; distSet(nums[i]); } return false; } }
相关文章推荐
- INSERT INTO .. ON DUPLICATE KEY更新多行记录
- mysql #1062 –Duplicate entry '1' for key 'PRIMARY'
- mysql ON DUPLICATE KEY UPDATE语句示例
- mysql error:#1062 Duplicate entry ‘***′ for key 1问题解决方法
- MySQL的Replace into 与Insert into on duplicate key update真正的不同之处
- Last_Errno: 1062,Last_Error: Error Duplicate entry
- MYSQL的REPLACE和ON DUPLICATE KEY UPDATE语句介绍解决问题实例
- insert into … on duplicate key update / replace into 多行数据介绍
- replace into… ON DUPLICATE KEY UPDATE
- Android Duplicate files copied in APK
- 获取windows系统的显示器个数
- mysql一次更新多条不同的记录
- JPA Many To Many Duplicate record in join table
- on duplicate key update简单使用
- ORACLE RAC ASM环境下DATAGUARD搭建步骤
- linker command failed with exit code 1 (use -v to see invocation)问题
- LeetCode Solution 06: 217Invert Binary Tree
- mysql中"ON DUPLICATE KEY UPDATE"语法遇到的问题
- Find the Duplicate Number
- duplicate symbols for architecture x86_64原因及解决办法