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;
        }
    }
}
相关推荐
Peter·Pan爱编程21 分钟前
CUDA系列之常用Runtime API简介
c++·算法
Shun_Tianyou24 分钟前
Python Day20 os模块 和 文件操作 及 例题分析
开发语言·数据结构·python·算法
逸风尊者33 分钟前
开发也能看懂的大模型:强化学习
java·算法·trae
hello 早上好38 分钟前
负载均衡、算法/策略
运维·算法·负载均衡
冲帕Chompa1 小时前
今日矩阵系列
数据结构·算法·矩阵
千夕见夕2 小时前
C 语言指针深度解析:从数组指针到指针函数的实战指南
c语言·c++·算法
Yuroo zhou3 小时前
无人机在复杂气流中,IMU 如何精准捕捉姿态变化以维持稳定?
单片机·嵌入式硬件·算法·机器人·无人机
Dream it possible!3 小时前
LeetCode 面试经典 150_数组/字符串_买卖股票的最佳时机(7_121_C++_简单)(贪心)
c++·leetcode·面试·贪心算法
xueyongfu3 小时前
PTX指令集基础以及warp级矩阵乘累加指令介绍
人工智能·线性代数·算法·矩阵
流星白龙3 小时前
【C++算法】89.多源BFS_01 矩阵
c++·算法·宽度优先