CF2130A.Submission is All You Need

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

Submission is All You Need

题目描述

对于一个由非负整数组成的多重集 TT,我们定义:

  • sum(T)\text{sum}(T) 表示 TT 中所有元素的和。例如,如果 T={0,1,1,3}T = \{0,1,1,3\},那么 sum(T)=0+1+1+3=5\text{sum}(T)=0+1+1+3=5
  • mex(T)\text{mex}(T) 表示不在 TT 中的最小非负整数。例如,如果 T={0,1,1,3}T = \{0,1,1,3\},那么 mex(T)=2\text{mex}(T)=2,因为 22 是最小的不在 TT 中的非负整数。

现在给定一个大小为 nn 的多重集 SS,其中包含非负整数。初始时,你的得分为 00。你可以进行如下操作任意次(可以为零次,顺序不限):

  • 选择 SS 的一个子集 SSS' \subseteq S(即 SS' 包含 SS 当前的部分元素),将 sum(S)\text{sum}(S') 加到你的得分上,然后从 SS 中移除 SS'
  • 选择 SS 的一个子集 SSS' \subseteq S,将 mex(S)\text{mex}(S') 加到你的得分上,然后从 SS 中移除 SS'

请你求出能够获得的最大得分。

输入格式

每组测试数据包含多组测试用例。第一行包含一个整数 tt1t1031 \le t \le 10^3),表示测试用例的组数。

每组测试用例的第一行包含一个整数 nn1n501 \le n \le 50)。

第二行包含 nn 个整数 S1,S2,,SnS_1, S_2, \ldots, S_n0Si500 \le S_i \le 50)。

输出格式

对于每组测试用例,输出一个整数,表示能够获得的最大得分。

说明/提示

在第一个测试用例中,一种可能的最优策略如下:

  • 选择 S={0,1}S'=\{0,1\},将 mex(S)=mex({0,1})=2\text{mex}(S')=\text{mex}(\{0,1\})=2 加到你的得分上,然后从 SS 中移除 SS'。此时你的得分为 22S={1}S=\{1\}
  • 选择 S={1}S'=\{1\},将 sum(S)=sum({1})=1\text{sum}(S')=\text{sum}(\{1\})=1 加到你的得分上,然后从 SS 中移除 SS'。此时你的得分为 33S=S=\varnothing

之后无法再进行操作。可以证明 33 是能够获得的最大得分。

由 ChatGPT 4.1 翻译

样例

2
3
0 1 1
3
1 2 3
3
6

在线编程 IDE

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