LeetCode292.Nim游戏

        思路:此题代码很简单,但是思想却不好理解,我们每次拿石头,一共有两种情况,A:石头总数为4的倍数,B:石头总数不为4的倍数,为什么我们会关注4的倍数呢。我们可以采取数学归纳法证明一下(证明对于4的倍数而言不管怎么拿都会得到还是4的倍数从8开始证明),就是因为对于4而言,谁面对4谁就输了,因为不管你拿1,2,3个剩下的都会被一次拿完,而对于2* 4=8个,面对8的时候不管拿x(1,2,3)个另一个人都可以4-x个使得剩下的为4个也就是输了(所以n=8时成立)。我们推广到4k数而言,当第一个人拿x(1,2,3),第二个人就拿4-x所有得到了4k-x+(4-x) = 4*(k-1)也为4的倍数(所以当数为4k而言成立);所以数学归纳法成立,所以对于任意4的倍数而言每次减小4最后都会得到4就代表着遇到4的倍数的人就输了,而对于情况B而言为什么就赢了呢?,因为对于一个不为4的倍数的值4* n>x>4* (n-1),x处于两个4的倍数之间他们之差为4,由于x不为4的倍数,所以,x距离最近的4的倍数值最大为3,所以只要面对到不是4的倍数的值我们一定可以取走(1,2,3)中的某个值导致剩下的值为4的倍数,而面对4倍数的人一定输(已经证明)。所以我们只需要关注4的倍数的值即可。
class Solution {
    public boolean canWinNim(int n) {
        return n%4!=0;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值