[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不能进行操作, A输

2: true   A将2变为1, B不能进行操作, A胜利

3: false  A将3变为2, B将2变为1, A面对1, 无法操作, A输

.....

n --->  n - x

如果 n-x 是true, 那么n 会false;   比如 3 ---> 2

如果 n-x 是false, 那么 n 会true; 比如 2 ---> 1

我们可以将全部的1~n的胜负都用循环跑出来

bool divisorGame(int N){
    int a[1010];  //0代表false, 1代表true
    for(int i = 0; i <= N; i++) a[i] = 0;  //默认全部为0
    a[1] = 0, a[2] = 1, a[3] = 0;
    for(int i = 4; i <= N; i++) {
        for(int j = 1; j < i; j++) {
            if(i % j == 0 && a[i-j] == 0) {   //一旦有一个数可以让i赢, 那么i就一定会赢, 最优的策略
                a[i] = 1;
                break;
            }
        }
    }

    if(a[N] == 0) return false;
    else return true;
}

看到一个dp题就要开始先推推样例, 你在推的过程中就可能会发现 奇数先手输, 偶数先手赢这个规律

为什么呢?

1: false

2: true

3: false

4: true

5: false

6: 我们将6-1   1的胜负是false, 按照我们说的规则, n-x=5 是false 则会 true    则6是true

7: 满足7的 x 只能为1  则 n-x = 6为 true, 则7为false

偶数减去1 一定为奇数, 奇数一定会输, 那么偶数就会赢   //我们要赢, 所以就让一个偶数减去奇数就好

奇数减去1 一定是偶数, 偶数会赢, 那么奇数就会输....减去1奇数会输, 我们能不能减去偶数呢?

答案是不能:  因为奇数不可能和一个偶数 被整除, 所以奇数一定减去的是奇数

所以如果按照博弈来做的话, 还可以直接判断奇数和偶数

原文地址:https://www.cnblogs.com/zoey686/p/11831267.html

时间: 2024-10-05 05:04:48

[1] LeetCode 1025.除数博弈的相关文章

leetcode 1025. 除数博弈(Divisor Game)

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

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处于输的情况,也就

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只能

[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 

除数博弈

描述: 爱丽丝和鲍勃一起玩游戏,他们轮流行动.爱丽丝先手开局. 最初,黑板上有一个数字 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 删除链表

[LeetCode] 877. Stone Game == [LintCode] 396. Coins in a Line 3_hard tag: 区间Dynamic Programming, 博弈

Alex and Lee play a game with piles of stones.  There are an even number of piles arranged in a row, and each pile has a positive integer number of stones piles[i]. The objective of the game is to end with the most stones.  The total number of stones

力扣(LeetCode)728. 自除数

自除数 是指可以被它包含的每一位数除尽的数. 例如,128 是一个自除数,因为 128 % 1 == 0,128 % 2 == 0,128 % 8 == 0. 还有,自除数不允许包含 0 . 给定上边界和下边界数字,输出一个列表,列表的元素是边界(含边界)内所有的自除数. 示例 1: 输入: 上边界left = 1, 下边界right = 22 输出: [1, 2, 3, 4, 5, 6, 7, 8, 9, 11, 12, 15, 22] 注意: 每个输入参数的边界满足 1 <= left <