题目:除数博弈
描述: 爱丽丝和鲍勃一起玩游戏,他们轮流行动。爱丽丝先手开局。
最初,黑板上有一个数字 
选出任一 


用 

如果玩家无法执行这些操作,就会输掉游戏。
只有在爱丽丝在游戏中取得胜利时才返回

示例:
输入:2
输出:true
解释:爱丽丝选择 1,鲍勃无法进行操作。
输入:3
输出:false
解释:爱丽丝选择 1,鲍勃也选择 1,然后爱丽丝无法进行操作。
解法一:递推
思路: 当先手处于 



可以定义 







class Solution {
public boolean divisorGame(int N) {
boolean[] f = new boolean[N + 5];
f[1] = false;
f[2] = true;
for (int i = 3; i <= N; ++i) {
for (int j = 1; j < i; ++j) {
if ((i % j) == 0 && !f[i - j]) {
f[i] = true;
break;
}
}
}
return f[N];
}
}
复杂度分析:
- 时间复杂度
。
- 空间复杂度
。
解法二:找规律
思路:
1、 如果 
2、 如果 

综上所述: 

class Solution {
public boolean divisorGame(int N) {
return N % 2 == 0;
}
}
复杂度分析:
- 时间复杂度
。
- 空间复杂度
。
。
。
。
。