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;
        }
    }
}
相关推荐
速易达网络9 分钟前
C语言常见推理题
java·c语言·算法
freedom_1024_26 分钟前
LRU缓存淘汰算法详解与C++实现
c++·算法·缓存
博语小屋33 分钟前
力扣11.盛水最多的容器(medium)
算法·leetcode·职场和发展
Swift社区40 分钟前
LeetCode 423 - 从英文中重建数字
算法·leetcode·职场和发展
点云SLAM1 小时前
算法与数据结构之二叉树(Binary Tree)
数据结构·算法·二叉树·深度优先·广度优先·宽度优先
小龙报1 小时前
《算法通关指南:算法基础篇 --- 一维前缀和 — 1. 【模板】一维前缀和,2.最大子段和》
c语言·数据结构·c++·算法·职场和发展·创业创新·visual studio
程序员三藏1 小时前
一文了解UI自动化测试
自动化测试·软件测试·python·selenium·测试工具·职场和发展·测试用例
敲敲了个代码1 小时前
11月3-5年Web前端开发面试需要达到的强度
前端·vue.js·学习·react.js·面试·职场和发展·web
bbq粉刷匠2 小时前
力扣--两数之和(Java)
java·leetcode
树在风中摇曳2 小时前
LeetCode 1658 | 将 x 减到 0 的最小操作数(C语言滑动窗口解法)
c语言·算法·leetcode