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];
    }
}
相关推荐
王老师青少年编程11 分钟前
csp信奥赛C++高频考点专项训练之贪心算法 --【哈夫曼贪心】:合并果子
c++·算法·贪心·csp·信奥赛·哈夫曼贪心·合并果子
叼烟扛炮1 小时前
C++第二讲:类和对象(上)
数据结构·c++·算法·类和对象·struct·实例化
天疆说1 小时前
【哈密顿力学】深入解读航天器交会最优控制中的Hamilton函数
人工智能·算法·机器学习
wuweijianlove2 小时前
关于算法设计中的代价函数优化与约束求解的技术7
算法
leoufung2 小时前
LeetCode 149: Max Points on a Line - 解题思路详解
算法·leetcode·职场和发展
样例过了就是过了2 小时前
LeetCode热题100 最长公共子序列
c++·算法·leetcode·动态规划
HXDGCL2 小时前
矩形环形导轨:自动化循环线的核心运动单元解析
运维·算法·自动化
谭欣辰2 小时前
C++ 排列组合完整指南
开发语言·c++·算法
代码中介商3 小时前
银行管理系统的业务血肉 —— 流程、状态机、输入校验与持久化(下篇)
c语言·算法
foundbug9993 小时前
自适应滤除直达波干扰的MATLAB实现
开发语言·算法·matlab