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;
        }
    }
}
相关推荐
Renas_TJOvO4 分钟前
排序算法汇总
java·数据结构·算法
Stardep5 分钟前
算法2—八大常用排序算法(下)
c语言·数据结构·笔记·算法·排序算法·1024程序员节
黑不溜秋的17 分钟前
C++ 模板专题 - 标签分派(Tag Dispatching)
开发语言·c++·算法
爱上语文22 分钟前
LeetCode每日一题
java·算法·leetcode
ProcedureStone33 分钟前
【算法】排序算法总结
c++·算法·排序算法
哦哦~92137 分钟前
Fluent和深度学习算法驱动的流体力学计算与应用
人工智能·深度学习·学习·算法
千里马-horse1 小时前
在OpenCL 中输出CLinfo信息
开发语言·c++·算法·opencl·1024程序员节
Y.O.U..1 小时前
Linux-计算机网络-epoll的LT,ET模式
linux·服务器·计算机网络·算法·1024程序员节