leetcode 292.Nim游戏

思路:数学

这有一点博弈论的味道,但是我们依然可以用数学的角度去思考。

我们的入手点在这里:

我们是先手的前提下,一共有4个石头,但是每个人只能一次拿其中的1-3个。在一共有4个石头的情况下,我们无论拿走几个,总会剩下对手可以拿到的范围的石头个数,我们必输;那么,反其道而行之,我们不让它的总数是4个就行了。

以此类推,当是8个,12个等等4的倍数的时候,我们可以按照4个4个的阶段进行解读,因为我们总是选择最优的解法,我们想赢,就必须把剩余的石子个数控制在4的倍数之外。

所以,我们只需要把三种可能的结果剩余石头算出来,然后判断它们其中有没有不是4的倍数的石子个数,有一个就证明我们可以采取其中的几个策略来实施。

复制代码
class Solution {
    public boolean canWinNim(int n) {
        if(n<=3)
        return true;
        else{
            int []arr=new int[3];
            arr[0]=n-1;
            arr[1]=n-2;
            arr[2]=n-3;
            if(arr[0]%4==0||arr[1]%4==0||arr[2]%4==0)
            return true;
            else
            return false;
        }
    }
}
相关推荐
爱编程的鱼15 分钟前
C# 数据类型||C# 类型转换
java·算法·c#
Haohao+++17 分钟前
leetcode面试经典算法题——2
算法·leetcode·面试
蓝白咖啡19 分钟前
LinkedList<Integer> 常用方法通俗讲解
数据结构·算法·jave
coder77771 小时前
js逆向分享
javascript·爬虫·python·算法·安全
冠位观测者1 小时前
【Leetcode 每日一题 - 补卡】1534. 统计好三元组
数据结构·算法·leetcode
明月看潮生1 小时前
青少年编程与数学 02-016 Python数据结构与算法 25课题、量子算法
python·算法·青少年编程·量子计算·编程与数学
weixin_445054721 小时前
力扣刷题-热题100题-第35题(c++、python)
c++·python·leetcode
JNU freshman2 小时前
C. Robin Hood in Town思考与理解
算法
_x_w3 小时前
【17】数据结构之图及图的存储篇章
数据结构·python·算法·链表·排序算法·图论
anscos3 小时前
Actran声源识别方法连载(二):薄膜模态表面振动识别
人工智能·算法·仿真软件·actran