292. Nim Game

本题大意:你和朋友正在玩一个小游戏。在桌子上放着一堆石头,一次允许你拿走1到3个石头,最后一次能全部拿走的人获胜。由你开始拿石头。你和朋友都很聪明,都能做出让自己赢的最佳决策。现在要写一个判定函数,给定石头的个数,判定你是否能赢。

例如共有4个石头,你就不可能赢得比赛:不管你拿几个石头,最后一个石头总是会被你的朋友拿走。

思路:找规律。n=1,赢;n=2,赢;n=3,赢;n=4,输;n=5,赢;n=6,赢;n=7,输;n=8,赢……

规律:n mod 4 == 0的时候就会输。

代码如下:

1 class Solution {
2 public:
3     bool canWinNim(int n) {
4         if(n%4 == 0)
5             return false;
6         else
7             return true;
8     }
9 };

 

转载于:https://www.cnblogs.com/jingyuewutong/p/5600618.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值