CF2115A Gellyfish and Flaming Peony
题目描述
Gellyfish 讨厌数学题,但她必须完成她的数学作业:
Gellyfish 得到一个包含 $n$ 个正整数 $a_1, a_2, \ldots, a_n$ 的数组。
她需要反复进行以下两步操作,直到数组 $a$ 的所有元素都相等为止:
1. 选择两个下标 $i$、$j$,满足 $1 \leq i, j \leq n$ 且 $i \neq j$。
2. 用 $\gcd(a_i, a_j)$ 替换 $a_i$ 的值。
现在,Gellyfish 想知道,最少需要多少次操作才能实现目标。
可以证明,Gellyfish 总是能够实现目标。
输入格式
每个测试点包含多个测试用例。第一行包含一个整数 $t$($1 \leq t \leq 5000$),表示测试用例的数量。接下来是每个测试用例的描述。
每个测试用例的第一行包含一个整数 $n$($1 \leq n \leq 5000$),表示数组的长度。
每个测试用例的第二行包含 $n$ 个整数 $a_1,a_2,\ldots,a_n$($1 \leq a_i \leq 5000$),表示数组的元素。
保证所有测试用例中 $n$ 的总和不超过 $5000$。
输出格式
对于每个测试用例,输出一个整数,表示实现目标所需的最小操作次数。
说明/提示
在第一个测试用例中,以下是一种最小化操作次数的方法:
1. 选择 $i = 3$,$j = 2$,用 $\gcd(a_3,a_2) = \gcd(30, 20) = 10$ 替换 $a_3$,此时 $a$ 变为 $[12, 20, 10]$。
2. 选择 $i = 1$,$j = 3$,用 $\gcd(a_1,a_3) = \gcd(12, 10) = 2$ 替换 $a_1$,此时 $a$ 变为 $[2, 20, 10]$。
3. 选择 $i = 2$,$j = 1$,用 $\gcd(a_2,a_1) = \gcd(20, 2) = 2$ 替换 $a_2$,此时 $a$ 变为 $[2, 2, 10]$。
4. 选择 $i = 3$,$j = 1$,用 $\gcd(a_3,a_1) = \gcd(10, 2) = 2$ 替换 $a_3$,此时 $a$ 变为 $[2, 2, 2]$。
由 ChatGPT 4.1 翻译