532. K-diff Pairs in an Array

Problem Statement

Given an array of integers nums and an integer k, return the number of unique k-diff pairs in the array.

A k-diff pair is an integer pair (nums[i], nums[j]) where:

  • 0 <= i, j < nums.length
  • i != j
  • |nums[i] - nums[j]| == k

Pairs (i, j) and (j, i) count as the same pair.

Examples

Example 1:

Input: nums = [3,1,4,1,5], k = 2
Output: 2
Explanation: The two 2-diff pairs are (1, 3) and (3, 5). (Two 1s yield one unique pair (1,3).)

Example 2:

Input: nums = [1,2,3,4,5], k = 1
Output: 4
Explanation: The four 1-diff pairs are (1,2), (2,3), (3,4), (4,5).

Example 3:

Input: nums = [1,3,1,5,4], k = 0
Output: 1
Explanation: The only 0-diff pair is (1, 1).

Constraints

  • 1 <= nums.length <= 10^4
  • -10^7 <= nums[i] <= 10^7
  • 0 <= k <= 10^7

Solution Approach

  • k == 0: We need pairs of the same value. Count how many distinct numbers appear more than once; each such number contributes one unique pair.
  • k > 0: We need pairs with difference exactly k. For each distinct value num, check whether num + k exists (checking only num + k avoids double-counting (a, a+k) and (a+k, a)). Use a frequency map or a set of values.

Solution 1: Single Hash Map (Frequencies)

One pass to build frequency map; then handle k==0 (count values with freq > 1) and k>0 (count values where num+k exists).

class Solution:
def findPairs(self, nums, k):
    dict[int, int> freqs
    for i in nums:
        freqs[i] += 1
    rtn = 0
    if k == 0:
        for ([_, freq] : freqs) :
        if (freq > 1) rtn += 1
     else :
    for ([num, _] : freqs) :
    if num + k in freqs:
        rtn += 1
return rtn

  • k == 0: Each value that appears at least twice gives exactly one unique pair (that value with itself).
  • k > 0: For each distinct num, we only check num + k so each pair is counted once.
  • Time: O(n). Space: O(n).

Solution 2: Map for k==0, Set for k>0

Same logic; k==0 uses a map to count frequencies, k>0 uses a set and checks num + k.

class Solution:
def findPairs(self, nums, k):
    rtn = 0
    if k == 0:
        dict[int, int> hm
        for num in nums:
            hm[num]++
        for (it = hm.begin() it != hm.end() it += 1) :
        if (it.second > 1) rtn += 1
     else :
    set[int> hs
    for num in nums:
        hs.insert(num)
    for (it = hs.begin() it != hs.end() it += 1) :
    if *it + k in hs:
        rtn += 1
return rtn

  • Time: O(n). Space: O(n).

Key Insights

  1. Unique pairs: Count by distinct values (or by one representative of each pair), not by indices.
  2. k == 0: Count distinct numbers that appear more than once.
  3. k > 0: Only check num + k (or only num - k) to count each pair once.
  4. Avoid k < 0: Problem states k >= 0; no need to handle negative k.