532-数组中的K-diff数对

Posted angelica-duhurica

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了532-数组中的K-diff数对相关的知识,希望对你有一定的参考价值。

532-数组中的K-diff数对

给定一个整数数组和一个整数 k, 你需要在数组里找到不同的 k-diff 数对。这里将 k-diff 数对定义为一个整数对 (i, j), 其中 i 和 j 都是数组中的数字,且两数之差的绝对值是 k.

示例 1:

输入: [3, 1, 4, 1, 5], k = 2
输出: 2
解释: 数组中有两个 2-diff 数对, (1, 3) 和 (3, 5)。
尽管数组中有两个1,但我们只应返回不同的数对的数量。

示例 2:

输入:[1, 2, 3, 4, 5], k = 1
输出: 4
解释: 数组中有四个 1-diff 数对, (1, 2), (2, 3), (3, 4) 和 (4, 5)。

示例 3:

输入: [1, 3, 1, 5, 4], k = 0
输出: 1
解释: 数组中只有一个 0-diff 数对,(1, 1)。

注意:

  1. 数对 (i, j) 和数对 (j, i) 被算作同一数对。
  2. 数组的长度不超过10,000。
  3. 所有输入的整数的范围在 [-1e7, 1e7]。

来源:力扣(LeetCode)
链接:https://leetcode-cn.com/problems/k-diff-pairs-in-an-array
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

    public int findPairs(int[] nums, int k) {
        int cnt = 0;
        if(nums.length <= 1 || k < 0) {
            return cnt;
        }

        Map<Integer, Integer> map = new HashMap<>();
        for (int num : nums) {
            map.put(num, map.getOrDefault(num, 0) + 1);
        }

        Set<Integer> set = new TreeSet<>(map.keySet()).descendingSet();
        for(Integer key : set) {
            if(k == 0 ) {
                if(map.getOrDefault(key, 0) >= 2) {
                    cnt++;
                }
            } else {
                if (map.containsKey(key - k)) {
                    cnt++;
                }
            }
        }
        return cnt;
    }
    public int findPairs(int[] nums, int k) {
        int count = 0;
        if (k < 0) {
            return count;
        }

        Arrays.sort(nums);
        
        int start = 0;
        int prev = Integer.MAX_VALUE;
        for (int i = 1; i < nums.length; i++) {
            if (nums[i] - nums[start] > k || prev == nums[start]) {
                if (++start != i) {
                    i--;
                }
            } else if (nums[i] - nums[start] == k) {
                prev = nums[start++];
                count++;
            }
        }
        return count;
    }

作者:zong-you-yi-tian-zhu
链接:https://leetcode-cn.com/problems/k-diff-pairs-in-an-array/solution/pai-xu-bian-li-zhi-xing-yong-shi-4-ms-zai-suo-you-/
来源:力扣(LeetCode)
著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

以上是关于532-数组中的K-diff数对的主要内容,如果未能解决你的问题,请参考以下文章

Python描述 LeetCode 532. 数组中的 k-diff 数对

Python描述 LeetCode 532. 数组中的 k-diff 数对

LeetCode 532 数组中的k-diff数对[双指针] HERODING的LeetCode之路

easy532. K-diff Pairs in an Array

k-diff 数对

java 532.阵列中的K-diff对(第1个).java