C. Raspberries

time limit per test

2 seconds

memory limit per test

256 megabytes

You are given an array of integers a1,a2,...,ana1,a2,...,an and a number kk (2≤k≤52≤k≤5). In one operation, you can do the following:

  • Choose an index 1≤i≤n1≤i≤n,
  • Set ai=ai+1ai=ai+1.

Find the minimum number of operations needed to make the product of all the numbers in the array a1⋅a2⋅...⋅ana1⋅a2⋅...⋅an divisible by kk.

Input

Each test consists of multiple test cases. The first line contains a single integer tt (1≤t≤1041≤t≤104) --- the number of test cases. Then follows the description of the test cases.

The first line of each test case contains two integers nn and kk (2≤n≤1052≤n≤105, 2≤k≤52≤k≤5) --- the size of the array aa and the number kk.

The second line of each test case contains nn integers a1,a2,...,ana1,a2,...,an (1≤ai≤101≤ai≤10).

It is guaranteed that the sum of nn over all test cases does not exceed 2⋅1052⋅105.

Output

For each test case, output the minimum number of operations needed to make the product of all the numbers in the array divisible by kk.

Example

Input

Copy

复制代码

15

2 5

7 3

3 3

7 4 1

5 2

9 7 7 3 9

5 5

5 4 1 2 3

7 4

9 5 1 5 9 5 1

3 4

6 3 6

3 4

6 1 5

3 4

1 5 9

4 4

1 4 1 1

3 4

3 5 3

4 5

8 9 9 3

2 5

1 6

2 5

10 10

4 5

1 6 1 1

2 5

7 7

Output

Copy

复制代码
2
2
1
0
2
0
1
2
0
1
1
4
0
4
3

Note

In the first test case, we need to choose the index i=2i=2 twice. After that, the array will be a=7,5a=7,5. The product of all the numbers in the array is 3535.

In the fourth test case, the product of the numbers in the array is 120120, which is already divisible by 55, so no operations are needed.

In the eighth test case, we can perform two operations by choosing i=2i=2 and i=3i=3 in any order. After that, the array will be a=1,6,10a=1,6,10. The product of the numbers in the array is 6060.

解题说明:此题是一道数学题,由于K范围很小,可以分类讨论。当k=4的时候存在给两个数都加1的情况,其他情况下的k都只可以给一个数一直加1直到这个数可以整除k。

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<vector>
using namespace std;
const int INF = 0x3f3f3f3f;
int main()
{
	int T; 
	cin >> T;
	while (T--)
	{
		int n, k; 
		cin >> n >> k;
		int a[100004];
		int ans = INF;
		int cal = 1;
		for (int i = 1; i <= n; i++)
		{
			cin >> a[i];
			cal *= a[i];
			if (a[i] % k == 0) 
			{
				ans = 0;
			}
			int t = a[i] / k + 1;
			ans = min(ans, t * k - a[i]);
		}
		if (k == 4)
		{
			int cnt1 = 0, cnt2 = 0;
			for (int i = 1; i <= n; i++)
			{
				switch (a[i] % 4)
				{
				case 1:
					cnt1++;
					break;
				case 2:
					cnt2++;
					break;
				case 3:
					break;
				default:
					ans = 0;
					break;
				}
			}
			if (cnt1 >= 2)
			{
				ans = min((int)2, ans);
			}
			if (cnt2 >= 2)
			{
				ans = 0;
			}
			if (cnt1 >= 1 && cnt2 >= 1)
			{
				ans = min((int)1, ans);
			}
		}
		cout << ans << endl;
	}
	return 0;
}
相关推荐
故事和你91几秒前
洛谷-【动态规划2】线性状态动态规划4
开发语言·数据结构·c++·算法·动态规划·图论
不吃土豆的马铃薯3 分钟前
Socket 网络编程实战教程
linux·服务器·开发语言·网络·c++·算法
小成2023032026520 分钟前
从C到C++
开发语言·c++
折哥的程序人生 · 物流技术专研20 分钟前
《Java 100 天进阶之路》第39篇:Java泛型方法的定义和使用
java·开发语言·后端·面试·求职招聘
天天进步201521 分钟前
Tunnelto 源码解析 #1:从 tunnelto --port 8000 看内网穿透的完整链路
开发语言
啄缘之间29 分钟前
8.【学习】工业级详细接口约束&覆盖率
开发语言·笔记·学习·uvm·sv
Chase_______30 分钟前
【Java基础核心知识点全解·09】Java 内存布局与垃圾回收详解:栈、堆、栈帧、GC Roots 与对象回收
java·开发语言
longxiangam1 小时前
esp-idf dsi 屏幕的驱动实现原理—— 关于零拷贝和 DMA 永续刷新
c语言·单片机·嵌入式硬件
江南十四行1 小时前
并发编程(四)
开发语言·python
葱卤山猪1 小时前
C++17 联合体
开发语言·c++