有 n
个硬币排成一条线。两个参赛者轮流从右边依次拿走 1 或 2 个硬币,直到没有硬币为止。拿到最后一枚硬币的人获胜。
请判定 先手玩家 必胜还是必败?
若必胜, 返回 true
, 否则返回 false
.
样例
样例 1:
输入: 1
输出: true
样例 2:
输入: 4
输出: true
解释:
先手玩家第一轮拿走一个硬币, 此时还剩三个.
这时无论后手玩家拿一个还是两个, 下一次先手玩家都可以把剩下的硬币拿完.
1、题目分析
这是典型的博弈类型的动态规划题目
2、确定状态
博弈类型的动态规划通常从第一部分析而不是最后一步。因为局面会变得越来越简单硬币的数量会越来越少。
当面对N个硬币的时候,先手第一步可以拿1个或者2个硬币。这样后手就面对N-1个硬币或者N-2个硬币。
通过上面这个图可以看出,如果取1个或者两个硬币后,能够让剩下的局面先手必败,则当前先手必胜。
因此我们可以假设状态f[i]表示面对i个硬币的时候,是否是否先手f[i]为True或者False。