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];
    }
}
相关推荐
祈祷苍天赐我java之术35 分钟前
解析常见的限流算法
java·数据结构·算法
Shinom1ya_1 小时前
算法 day 34
算法
啊董dong1 小时前
课后作业-2025-10-26
c++·算法·noi
liu****1 小时前
1.模拟算法
开发语言·c++·算法·1024程序员节
小猪咪piggy1 小时前
【算法】day10 分治
数据结构·算法·排序算法
又是忙碌的一天1 小时前
算法学习 13
数据结构·学习·算法
June`1 小时前
前缀和算法:高效解决区间和问题
算法·1024程序员节
再卷也是菜1 小时前
算法基础篇(9)倍增与离散化
c++·算法
ゞ 正在缓冲99%…4 小时前
leetcode2826.将三个组排序
算法·leetcode·动态规划
qq_401700415 小时前
matlab学习
学习·算法·matlab