CF1762A.Divide and Conquer

传统题 时间 2000 ms 内存 256 MiB 3 尝试 1 已通过 1 标签

Divide and Conquer

题目描述

如果一个数组 bb 的元素之和是偶数,则称数组 bb 是好的。

给定一个由 nn 个正整数组成的数组 aa。每次操作,你可以选择一个下标 ii,并将 aia_i 变为 ai2\lfloor \frac{a_i}{2} \rfloor^\dagger

请你求出将 aa 变为好的数组所需的最少操作次数(可以为 00)。可以证明,总是存在一种方法可以将 aa 变为好的。

^\dagger x\lfloor x \rfloor 表示向下取整函数,即不大于 xx 的最大整数。例如,2.7=2\lfloor 2.7 \rfloor = 2π=3\lfloor \pi \rfloor = 35=5\lfloor 5 \rfloor = 5

输入格式

每组测试数据包含多组测试用例。第一行包含一个整数 tt1t10001 \leq t \leq 1000),表示测试用例的数量。接下来是每组测试用例的描述。

每组测试用例的第一行包含一个整数 nn1n501 \leq n \leq 50),表示数组 aa 的长度。

每组测试用例的第二行包含 nn 个用空格分隔的整数 a1,a2,,ana_1,a_2,\ldots,a_n1ai1061 \leq a_i \leq 10^6),表示数组 aa

注意,所有测试用例中 nn 的总和没有上界。

输出格式

对于每组测试用例,输出将 aa 变为好的数组所需的最少操作次数。

说明/提示

在第一个测试用例中,数组 aa 已经是好的。

在第二个测试用例中,我们可以对下标 22 执行两次操作。第一次操作后,数组 aa 变为 [7,2][7,2]。再次对下标 22 操作后,aa 变为 [7,1][7,1],此时是好的。可以证明,不可能用更少的操作次数使 aa 变为好的。

在第三个测试用例中,如果对下标 11 执行一次操作,aa 变为 [0,2,4][0,2,4]。由于 [0,2,4][0,2,4] 是好的,所以答案是 11

在第四个测试用例中,需要对下标 11 执行四次操作。所有操作后,aa 变为 [0][0]。可以证明,不可能用更少的操作次数使 aa 变为好的。

由 ChatGPT 4.1 翻译

样例

4
4
1 1 1 1
2
7 4
3
1 2 4
1
15
0
2
1
4

在线编程 IDE

建议全屏模式获得最佳体验