Post

1620 Check If Array Pairs Are Divisible By K

1620 Check If Array Pairs Are Divisible By K

Check If Array Pairs Are Divisible by k image

Given an array of integers arr of even length n and an integer k.

We want to divide the array into exactly n / 2 pairs such that the sum of each pair is divisible by k.

Return true* If you can find a way to do that or false otherwise*.

 

Example 1:

1
2
3
4
5
**Input:** arr = [1,2,3,4,5,10,6,7,8,9], k = 5
**Output:** true
**Explanation:** Pairs are (1,9),(2,8),(3,7),(4,6) and (5,10).

Example 2:

1
2
3
4
5
**Input:** arr = [1,2,3,4,5,6], k = 7
**Output:** true
**Explanation:** Pairs are (1,6),(2,5) and(3,4).

Example 3:

1
2
3
4
5
**Input:** arr = [1,2,3,4,5,6], k = 10
**Output:** false
**Explanation:** You can try all possible pairs to see that there is no way to divide arr into 3 pairs each with sum divisible by 10.

 

Constraints:

1
2
3
4
5
arr.length == n
1 <= n <= 105
n is even.
-109 <= arr[i] <= 109
1 <= k <= 105
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27

class Solution:
    def canArrange(self, arr: List[int], k: int) -> bool:
        dic = {}
        for m in arr:
                if m%k == 0:
                    continue
                if m%k in dic:
                    dic[m%k] += 1
                else:
                    dic[m%k] = 1
        for m,v in dic.items():
            if m == k/2 and k % 2 == 0 and v % 2 != 0:
                return False
            if k-m not in dic or v != dic[k-m]:
                return False

        return True


            

        



This post is licensed under CC BY 4.0 by the author.