题目描述:
    给定一个整数数组和一个整数 k,判断数组中是否存在两个不同的索引 i 和 j,使得 nums [i] = nums [j],并且 i 和 j 的差的 绝对值 至多为 k。

    链接:https://leetcode-cn.com/problems/contains-duplicate-ii

    思路:
    1.map收集下标和对应元素,一次遍历,对比
    2.为了考虑多个相同元素的情况,使用map中使用数组收集下标
    代码实现:

    1. class Solution {
    2. public boolean containsNearbyDuplicate(int[] nums, int k) {
    3. Map<Integer,ArrayList<Integer>> map = new HashMap<Integer,ArrayList<Integer>>();
    4. for(int i = 0;i < nums.length;i++) {
    5. int val = nums[i];
    6. if (map.get(val) == null) {
    7. map.put(val, new ArrayList<Integer>());
    8. }
    9. ArrayList<Integer> list = map.get(val);
    10. for(int n : list) {
    11. if (Math.abs(i-n) <= k ) {
    12. return true;
    13. }
    14. }
    15. list.add(i);
    16. }
    17. return false;
    18. }
    19. }