#ATarc112c. [ARC112C] DFS Game
[ARC112C] DFS Game
题目描述
高桥君和青木君用一棵有 个顶点的有根树进行游戏。树的每个顶点编号为 到 。树的根为顶点 ,对于 ,顶点 的父节点为 。最开始,每个顶点上都有 枚硬币,且顶点 上放有棋子。
高桥君和青木君轮流进行如下操作,高桥君先手:
- 如果棋子所在的顶点上有硬币,则获得该硬币,结束本回合。
- 如果棋子所在的顶点上没有硬币,则按以下规则移动棋子(或结束游戏):
- 如果该顶点的子节点中存在有硬币的顶点,可以选择其中任意一个,将棋子移动到该顶点,结束本回合。
- 如果不存在这样的子节点,且当前顶点是根节点,则游戏结束。否则,将棋子移动到当前顶点的父节点,结束本回合。
高桥君和青木君都会采取最优策略,使自己获得的硬币数量最大。请你求出高桥君最终能获得的硬币数量。
输入格式
输入为以下格式,从标准输入读入。
输出格式
输出在双方都采取最优策略时,高桥君能获得的硬币数量。
样例 1
输入
10
1 2 3 4 5 6 7 8 9
输出
10
样例 2
输入
5
1 2 3 1
输出
2
样例 3
输入
10
1 1 3 1 3 6 7 6 6
输出
5
说明/提示
限制条件
样例解释 1
由于双方都没有选择的余地,游戏必然按如下顺序进行,因此高桥君能获得所有硬币。
- 高桥君获得顶点 上的硬币。
- 青木君将棋子移动到顶点 。
- 高桥君获得顶点 上的硬币。
- 青木君将棋子移动到顶点 。
- 高桥君获得顶点 上的硬币。
- 青木君将棋子移动到顶点 。
- 高桥君将棋子移动到顶点 。
- 青木君将棋子移动到顶点 。
- 高桥君将棋子移动到顶点 。
- 青木君将棋子移动到顶点 。
- 游戏结束。
样例解释 2
首先,高桥君获得顶点 上的硬币。之后,青木君可以选择将棋子移动到顶点 或顶点 。如果移动到顶点 ,青木君最终只能获得顶点 上的硬币;如果移动到顶点 ,青木君最终能获得顶点 上的硬币。由于青木君会采取最优策略,他会选择移动到顶点 。因此,高桥君最终能获得 枚硬币。
由 ChatGPT 4.1 翻译