#UnknownID24. XHXMMMl31UFTWg#^_@;

XHXMMMl31UFTWg#^_@;

Statement

You have a hand of n n cards, where each card has a number written on it, and a fixed integer k k . You can perform the following operation any number of times:

  • Choose any k k cards from your hand that all have the same number.
  • Exchange these cards for k1 k-1 cards, each of which can have any number you choose (including the number written on the cards you just exchanged).

Here is one possible sequence of operations for the first example case, which has k=3 k=3 :

What is the minimum number of cards you can have in your hand at the end of this process?

Format

Input

The first line of the input contains a single integer t t ( 1t500 1 \le t \le 500 ) — the number of test cases. The description of the test cases follows.

The first line of each test case contains two integers n n and k k ( 1n100 1 \le n \le 100 , 2k100 2 \le k \le 100 ) — the number of cards you have, and the number of cards you exchange during each operation, respectively.

The next line of each test case contains n n integers c1,c2,cn c_1, c_2, \ldots c_n ( 1ci100 1 \le c_i \le 100 ) — the numbers written on your cards.

Output

For each test case, output a single integer — the minimum number of cards you can have left in your hand after any number of operations.

Sample

7
5 3
4 1 1 4 4
1 10
7
7 2
4 2 1 100 5 2 3
10 4
1 1 1 1 1 1 1 1 1 1
5 2
3 8 1 48 7
6 2
10 20 30 10 20 40
6 3
10 20 30 10 20 40
2
1
1
3
5
1
6