数学简单 LeetCode292. Nim 游戏 NC230 Nim游戏

292. Nim 游戏

描述

你和你的朋友,两个人一起玩 Nim 游戏:
桌子上有一堆石头。
你们轮流进行自己的回合, 你作为先手 。
每一回合,轮到的人拿掉 1 - 3 块石头。
拿掉最后一块石头的人就是获胜者。
假设你们每一步都是最优解。请编写一个函数,来判断你是否可以在给定石头数量为 n 的情况下赢得游戏。如果可以赢,返回 true;否则,返回 false 。

import java.util.*;
public class Solution {
    public boolean NimGame (int n) {
//         if(n < 4){
//             return true;
//         }
//         boolean[] dp = new boolean[n];
//         dp[0] = true;
//         dp[1] = true;
//         dp[2] = true;
//         dp[3] = false;
//         for(int i = 4; i < n; i++){
//             dp[i] = !dp[i-1] || !dp[i-2] || !dp[i-3];
//         }
//         return dp[n-1];
        return !(n % 4 == 0);
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值