leetcode 1025. 除数博弈(Divisor Game)

目录

  • 题目描述:
  • 示例 1:
  • 示例 2:
  • 解法:

题目描述:

爱丽丝和鲍勃一起玩游戏,他们轮流行动。爱丽丝先手开局。

最初,黑板上有一个数字 N 。在每个玩家的回合,玩家需要执行以下操作:

  • 选出任一 x,满足 0 < x < NN % x == 0
  • N - x 替换黑板上的数字 N

如果玩家无法执行这些操作,就会输掉游戏。

只有在爱丽丝在游戏中取得胜利时才返回 true,否则返回 false。假设两个玩家都以最佳状态参与游戏。

示例 1:

输入:2
输出:true
解释:爱丽丝选择 1,鲍勃无法进行操作。

示例 2:

输入:3
输出:false
解释:爱丽丝选择 1,鲍勃也选择 1,然后爱丽丝无法进行操作。

提示:

  1. 1 <= N <= 1000

解法:

class Solution {
public:
    bool divisorGame(int N) {
        vector<bool> flag(1001, false);
        flag[2] = true;
        if(N <= 3){
            return flag[N];
        }else{
            for(int i = 4; i <= N; i++){
                bool canWin = false;
                for(int j = 1; j < i; j++){
                    if(i%j == 0 && flag[i-j] == false){
                        canWin = true;
                        break;
                    }
                }
                if(canWin){
                    flag[i] = true;
                }
            }
            return flag[N];
        }
    }
};

原文地址:https://www.cnblogs.com/zhanzq/p/10749090.html

时间: 2024-10-05 05:50:20

leetcode 1025. 除数博弈(Divisor Game)的相关文章

[1] LeetCode 1025.除数博弈

做的LeetCode第一题....疯狂错误编译, 原来true or false 是给你return的, 函数已经写好了..... 完整题目 题目大意: A B 两人玩游戏 , 轮流进行, A 先手, A 胜利则输出 true, A失败输出 false 游戏内容: 给一个数字n, 你可以进行一次操作,  将 n 变为 n-x, n的要求: x必须满足 n % x == 0(n可以被x整除) 并且  0 < x < n 分析: 1:  false   A先手 没有数字被1整除还小于1的 所以A不

Leetcode之动态规划(DP)专题-1025. 除数博弈(Divisor Game)

爱丽丝和鲍勃一起玩游戏,他们轮流行动.爱丽丝先手开局. 最初,黑板上有一个数字 N .在每个玩家的回合,玩家需要执行以下操作: 选出任一 x,满足 0 < x < N 且 N % x == 0 . 用 N - x 替换黑板上的数字 N . 如果玩家无法执行这些操作,就会输掉游戏. 只有在爱丽丝在游戏中取得胜利时才返回 True,否则返回 false.假设两个玩家都以最佳状态参与游戏. 示例 1: 输入:2 输出:true 解释:爱丽丝选择 1,鲍勃无法进行操作. 示例 2: 输入:3 输出:f

LeetCode 5024 除数博弈 --(简单博弈论)

今天在LeetCode的看到一到题目 这道题目有点坑,没有思路的话容易钻牛角. 刚刚开始时,我想的是直接用while循环来模拟计算,后来觉得这么好麻烦,也有复制的逻辑在里面.后面我推导了一下 以下是我的推导过程,爱丽丝简称 A 鲍勃 简称B 当num=2时,A=1-->num=num-1=1,A赢 当num=3时,A只能出1,-->num=num-1=2,此时B正好处于num=2的情况,所以B可以用之前A的策略,B赢 当num=4时,A可以出1 或 2,但是为了赢,A必须让B处于输的情况,也就

[Swift]LeetCode1025. 除数博弈 | Divisor Game

Alice and Bob take turns playing a game, with Alice starting first. Initially, there is a number N on the chalkboard.  On each player's turn, that player makes a move consisting of: Choosing any x with 0 < x < N and N % x == 0. Replacing the number 

LeetCode 1025. Divisor Game

题目链接:https://leetcode.com/problems/divisor-game/ 题意:Alice和Bob玩一个游戏,Alice先开始.最初,黑板上有一个数字N.每一轮,选手首先需要选择一个数x(0<x<N且N%x==0),并将黑板上的数字N替换成N-x.如果哪个选手无法继续操作,则意味着输掉了游戏.如果Alice赢了返回true. 分析: (1)先从最简单的case入手.N=1,Alice必败:N=2,Alice只能选择1,则Bob必败,Alice必胜:N=3,Alice只能

除数博弈

描述: 爱丽丝和鲍勃一起玩游戏,他们轮流行动.爱丽丝先手开局. 最初,黑板上有一个数字 N .在每个玩家的回合,玩家需要执行以下操作: 选出任一 x,满足 0 < x < N 且 N % x == 0 .用 N - x 替换黑板上的数字 N .如果玩家无法执行这些操作,就会输掉游戏. 只有在爱丽丝在游戏中取得胜利时才返回 True,否则返回 false.假设两个玩家都以最佳状态参与游戏. 示例 1: 输入:2输出:true解释:爱丽丝选择 1,鲍勃无法进行操作. 示例 2: 输入:3输出:fa

leet

# 题名1 两数之和    2 两数相加    3 无重复字符的最长子串    4 寻找两个有序数组的中位数    5 最长回文子串    6 Z 字形变换    7 整数反转    8 字符串转换整数 (atoi)    9 回文数    10 正则表达式匹配    11 盛最多水的容器    12 整数转罗马数字    13 罗马数字转整数    14 最长公共前缀    15 三数之和    16 最接近的三数之和    17 电话号码的字母组合    18 四数之和    19 删除链表

[LeetOode][Java] Divide Two Integers

题目: Divide two integers without using multiplication, division and mod operator. If it is overflow, return MAX_INT. 题意: 不使用乘法,除法和取余操作,令两个整数相除. 如果溢出,就返回 MAX_INT. 算法分析: 参考博客http://blog.csdn.net/linhuanmars/article/details/20024907 * 我们知道任何一个整数可以表示成以2的幂

【leetcode】1283. Find the Smallest Divisor Given a Threshold

题目如下: Given an array of integers nums and an integer threshold, we will choose a positive integer divisor and divide all the array by it and sum the result of the division. Find the smallest divisor such that the result mentioned above is less than o