CFCF2154C1.No Cost Too Great (Easy Version)
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
这是该问题的简单版本。与困难版本的区别在于,本题中 bi=1 对于所有 i(1≤i≤n)。只有当你解决了所有版本才能进行“hack”。
你有两个长度均为 n 的正整数数组 a 和 b。你可以进行以下操作任意次(也可以一次都不做):
- 选择一个整数 i(1≤i≤n),将 ai 增加 1,花费为 bi。
请你求出使得存在两个整数 i,j(1≤i<j≤n),满足 gcd(ai,aj)>1 的最小总花费。
gcd(x,y) 表示整数 x 和 y 的最大公约数,详见最大公约数。
输入格式
每组测试数据包含多组测试用例。第一行包含一个整数 t(1≤t≤104),表示测试用例的数量。
每个测试用例的第一行包含一个整数 n(2≤n≤2⋅105),表示数组 a 的长度。
第二行包含 n 个整数 a1,a2,…,an(1≤ai≤2⋅105)。
第三行包含 n 个整数 b1,b2,…,bn,其中 bi=1。
所有测试用例中 n 的总和不超过 2⋅105。
输出格式
对于每组测试用例,输出最小花费。
输入输出样例
输入#1
6 2 1 1 1 1 2 4 8 1 1 5 1 1 727 1 1 1 1 1 1 1 2 3 11 1 1 3 2 7 11 1 1 1 3 7 12 13 1 1 1
输出#1
2 0 2 1 1 1
说明/提示
在第一个测试用例中,可以如下操作:[1,1]x=1[2,1]x=2[2,2]。此时 gcd(a1,a2)=gcd(2,2)=2,因此 gcd(a1,a2)>1。可证明这是最小的花费。
在第二个测试用例中,本来就已经有 gcd(a1,a2)=4,因此无须进行任何操作。