zoukankan      html  css  js  c++  java
  • 292. Nim Game

    You are playing the following Nim Game with your friend: There is a heap of stones on the table, each time one of you take turns to remove 1 to 3 stones. The one who removes the last stone will be the winner. You will take the first turn to remove the stones.

    Both of you are very clever and have optimal strategies for the game. Write a function to determine whether you can win the game given the number of stones in the heap.

    Example:

    Input: 4
    Output: false 
    Explanation: If there are 4 stones in the heap, then you will never win the game;
                 No matter 1, 2, or 3 stones you remove, the last stone will always be 
                 removed by your friend.
    class Solution {
        public boolean canWinNim(int n) {
            return (n % 4 != 0);
        }
    }

    不愧是simple

    Let us think of the small cases. It is clear that if there are only one, two, or three stones in the pile, and it is your turn, you can win the game by taking all of them. Like the problem description says, if there are exactly four stones in the pile, you will lose. Because no matter how many you take, you will leave some stones behind for your opponent to take and win the game. So in order to win, you have to ensure that you never reach the situation where there are exactly four stones on the pile on your turn.

    Similarly, if there are five, six, or seven stones you can win by taking just enough to leave four stones for your opponent so that they lose. But if there are eight stones on the pile, you will inevitably lose, because regardless whether you pick one, two or three stones from the pile, your opponent can pick three, two or one stone to ensure that, again, four stones will be left to you on your turn.

    It is obvious that the same pattern repeats itself for n=4,8,12,16,dotsn=4,8,12,16,…, basically all multiples of 44.

    留4特别重要

    
    
    class Solution {
        public boolean canWinNim(int n) {
            if(n < 4) return true;
            else{
            boolean[] dp = new boolean[n+1];
            dp[1] = true;
            dp[2] = true;
            dp[3] = true;
            for(int i = 4; i <= n; i++){
                dp[i] = !dp[i - 1] || !dp[i - 2] || !dp[i - 3];
            }
            return dp[n];
            }
        }
    }
    
    
    
     

    还是dp好点,但是会MemoryLE,

  • 相关阅读:
    给一个二维数组随机赋值
    sql server use WAITFOR DELAY to wait some milliseconds
    sql server print time with milliseconds
    UE4 LeapMotion 获取手掌朝向
    Unity打包Android出现Failed to find Build Tools revision
    UE4中Yaw,Roll,Pitch分别对应什么轴?
    Unity 遍历场景所有物体(包括隐藏及被禁用的物体)
    C#-Linq扩展方法DistinctBy
    Unity编辑器扩展--Scene Manager
    Unity查找功能编辑器扩展Searcher
  • 原文地址:https://www.cnblogs.com/wentiliangkaihua/p/11804137.html
Copyright © 2011-2022 走看看