1025. 除数博弈

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

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

选出任一 x,满足 0 < x < n 且 n % x == 0 。

用 n - x 替换黑板上的数字 n 。

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

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


需要对该问题进行建模。dp[i]表示爱丽丝选择第i个数字是否能赢。对于j满足i%j==0,需要检查dp[i-j]是否满足条件。满足的话,dp[i]也为true。

java 复制代码
class Solution {
    public boolean divisorGame(int n) {
        /**
        选0-n之间的数,且n%x==0
        用n-x替换n
         */
        int num = n;
        boolean[] dp = new boolean[n+6];
        dp[1] = false;
        dp[2] = true;
        for(int i=3; i<=n; i++) {
            for(int j=1; j<i; j++) {
                if((i%j == 0) && !dp[i-j]) {
                    dp[i] = true;
                    break;
                }
            }

        }
        return dp[n];
    }
}
相关推荐
枫景Maple6 分钟前
LeetCode 2297. 跳跃游戏 VIII(中等)
算法·leetcode
鑫鑫向栄7 分钟前
[蓝桥杯]修改数组
数据结构·c++·算法·蓝桥杯·动态规划
鑫鑫向栄7 分钟前
[蓝桥杯]带分数
数据结构·c++·算法·职场和发展·蓝桥杯
小wanga1 小时前
【递归、搜索与回溯】专题三 穷举vs暴搜vs回溯vs剪枝
c++·算法·机器学习·剪枝
天宫风子1 小时前
线性代数小述(一)
线性代数·算法·矩阵·抽象代数
hjyowl1 小时前
题解:AT_abc407_c [ABC407C] Security 2
c语言·开发语言·算法
ai产品老杨2 小时前
减少交通拥堵、提高效率、改善交通安全的智慧交通开源了。
前端·vue.js·算法·ecmascript·音视频
小于不是小鱼呀3 小时前
手撕 K-Means
人工智能·算法·机器学习
m0_740154673 小时前
K-Means颜色变卦和渐变色
算法·机器学习·kmeans