首页 > 其他 > 详细

[LeetCode] 219. Contains Duplicate II ☆(存在重复元素2)

时间:2019-06-28 12:43:28      阅读:101      评论:0      收藏:0      [点我收藏+]

每天一算:Contains Duplicate II

描述

给出1个整形数组nums和1个整数k,是否存在索引i和j,使得nums[i] == nums[j] 且i和j之间的差不超过k

Example 1:
Input: nums = [1,2,3,1], k = 3
Output: true.

Example 2:
Input: nums = [1,0,1,1], k = 1
Output: true

Example 3:
Input: nums = [1,2,3,1,2,3], k = 2
Output: false

解析

考虑用滑动窗口与查找表来解决。

  • 设置查找表record,用来保存每次遍历时插入的元素,record的最大长度为k

  • 遍历数组nums,每次遍历的时候在record查找是否存在相同的元素,如果存在则返回true,遍历结束

  • 如果此次遍历在record未查找到,则将该元素插入到record中,而后查看record的长度是否为k + 1

  • 如果此时record的长度是否为k + 1,则删减record的元素,该元素的值为nums[i - k]

  • 如果遍历完整个数组nums未查找到则返回false

代码

public static boolean containsDuplicate2(int[] n, int k) {
        if (n == null || n.length < k) {
            return false;
        }
        List<Integer> list = new ArrayList<>(k);
        for (int i = 0; i < n.length; i++) {
            if (!list.contains(n[i])) {
                list.add(n[i]);
                
                if (list.size() > k) {
                    list.remove(0);
                }
            } else {
                return true;
            }
        }
        return false;
    }

 

[LeetCode] 219. Contains Duplicate II ☆(存在重复元素2)

原文:https://www.cnblogs.com/fanguangdexiaoyuer/p/11101906.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!