CFCF2190A.Sorting Game
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
爱丽丝(Alice)和鲍勃(Bob)在一个长度为 n 的二进制字符串 s(仅由字符 0 和 1 组成)上进行游戏。爱丽丝先行,两名玩家交替行动。
在每一回合中,玩家需要选择一组索引序列 i1,i2,…,im(满足 1≤i1<i2<⋯<im≤n),且这些位置上的字符构成非递增序列(即 si1≥si2≥⋯≥sim)。随后,玩家将这些位置上的字符重新排列为非递减顺序。
形式化地说,设选中的字符包含 z 个 0 和 o 个 1(满足 z+o=m),则本次操作会将位置 i1,i2,…,im 上的字符替换为 z 个 0 后接 o 个 1 的序列。仅当操作严格改变字符串 s 时,该操作才有效(这意味着必须满足 z≥1 且 o≥1)。
无法做出有效操作的玩家输掉游戏。
假设两名玩家均采取最优策略,请判断最终的获胜者。若爱丽丝获胜,需输出她在获胜策略中可采取的首个有效操作。
输入格式
输入包含多组测试用例。第一行输入测试用例数 t(1≤t≤104),后续为各测试用例的描述。
每组测试用例的第一行输入一个整数 n(1≤n≤2⋅105),表示字符串 s 的长度。
第二行输入一个长度为 n 的二进制字符串 s(仅包含 0 和 1)。
保证所有测试用例的 n 之和不超过 2⋅105。
输出格式
对于每组测试用例,输出一行或三行内容:
- 若鲍勃采取最优策略后获胜,输出单行字符串 "Bob";
- 否则,输出三行内容:第一行输出 "Alice",第二行输出一个整数 m(2≤m≤n),第三行输出 m 个互不相同的整数 i1,i2,…,im(1≤i1<i2<⋯<im≤n)—— 即爱丽丝首次操作选择的索引序列。
你输出的索引序列必须符合题目描述的有效操作规则,且索引需按升序打印。若存在多个获胜操作,输出任意一个即可。
输入输出样例
输入#1
3 3 000 2 10 3 101
输出#1
Bob Alice 2 1 2 Alice 2 1 2
说明/提示
第一个样例中,不存在能改变字符串 s 的有效操作,因此鲍勃直接获胜。
第三个样例中,爱丽丝可选择子序列 [1,2] 并对其排序,操作后字符串 s 变为 011。此后鲍勃无法做出有效操作,爱丽丝获胜。