题目描述
AC代码
/*
1.两个人选完所有的数后,得到的和都不够desireTotal(即前m项和<desireTotal),那么第一个玩家肯定会输;
2.如果t<=1,那么第一个玩家可以直接获胜
*/
class Solution {
//f[0]表示整数1是否被选择过,f[1]表示整数2是否被选择过,null代表还未开始计算过
Boolean[] f=null;
int m;
public boolean canIWin(int _m, int t) {
m=_m;
f=new Boolean[1<<(m+1)];
if(t<=1) return true;
if(m*(m+1)<t*2) return false;
return dfs(0,t);
}
boolean dfs(int u,int t){
if(f[u]!=null){
return f[u];
}
if(t<=0) return f[u]=false;
for(int i=1;i<=m;i++){
//当前这个数还没有被选择过,而且选完这个数之后下一个玩家必输
if((u&1<<i)==0&&!dfs(u+(1<<i),t-i))
return f[u]=true;
}
return f[u]=false;
}
}