CF1909D.Split Plus K
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
⠀
There are n positive integers a1,a2,…,an on a blackboard. You are also given a positive integer k . You can perform the following operation some (possibly 0 ) times:
- choose a number x on the blackboard;
- erase one occurrence of x ;
- write two positive integers y , z such that y+z=x+k on the blackboard.
Is it possible to make all the numbers on the blackboard equal? If yes, what is the minimum number of operations you need?
输入格式
Each test contains multiple test cases. The first line contains the number of test cases t ( 1≤t≤104 ). The description of the test cases follows.
The first line of each test case contains two integers n , k ( 1≤n≤2⋅105 , 1≤k≤1012 ) — the number of integers initially on the blackboard and the constant k .
The second line of each test case contains n integers a1,a2,…,an ( 1≤ai≤1012 ) — the initial state of the blackboard.
It is guaranteed that the sum of n over all test cases does not exceed 2⋅105 .
输出格式
For each test case, output a single line containing an integer: the minimum number of operations you need to make all the numbers on the blackboard equal, or −1 if it is impossible.
输入输出样例
输入#1
9 2 1 3 4 2 3 7 11 3 10 100 40 100 2 1 1 2 2 2 1 2 1 327869541 327869541 5 26250314066 439986238782 581370817372 409476934981 287439719777 737637983182 5 616753575719 321037808624 222034505841 214063039282 441536506916 464097941819 5 431813672576 393004301966 405902283416 900951084746 672201172466 518769038906
输出#1
3 1 4 -1 -1 0 3119 28999960732 -1
说明/提示
In the first test case, k=1 . You can make all the numbers on the blackboard equal to 2 with the following operations:
- Erase x=4 and write (y,z)=(2,3) . Note that y+z=x+k . The blackboard now contains the multiset {3,2,3} .
- Erase x=3 and write (y,z)=(2,2) . Note that y+z=x+k . The blackboard now contains {2,2,2,3} .
- Erase x=3 and write (y,z)=(2,2) . Note that y+z=x+k . The blackboard now contains {2,2,2,2,2} .
This makes all the numbers equal in 3 operations. It can be shown that you cannot make all the numbers equal in less than 3 operations.
In the second test case, k=3 . You can make all the numbers on the blackboard equal to 7 with the following operation:
- Erase x=11 and write (y,z)=(7,7) . Note that y+z=x+k . The blackboard now contains {7,7,7} .
In the third test case, k=10 . You can make all the numbers on the blackboard equal to 40 with the following operations:
- Erase x=100 and write (y,z)=(70,40) . Note that y+z=x+k . The blackboard now contains {70,40,40,100} .
- Erase x=70 and write (y,z)=(40,40) . Note that y+z=x+k . The blackboard now contains {40,40,40,40,100} .
- Erase x=100 and write (y,z)=(40,70) . Note that y+z=x+k . The blackboard now contains {40,40,40,40,40,70} .
- Erase x=70 and write (y,z)=(40,40) . Note that y+z=x+k . The blackboard now contains {40,40,40,40,40,40,40} .
In the fourth and in the fifth test case, you can show that it is impossible to make all the numbers on the blackboard equal.