力扣486预测赢家 极小化极大 动态规划
class Solution {
public boolean PredictTheWinner(int[] nums) {
int n = nums.length;
int dp[][] = new int[n][n]; //dp[i][j]是在i-j内当前玩家先手取数能领先对手的最大值
for (int i = 0; i < n; ++i) {
dp[i][i] = nums[i];
}
for (int j = 1; j < n; ++j) {
for (int i = j - 1; i >= 0; --i) {
dp[i][j] = Math.max(nums[i] - dp[i + 1][j], nums[j] - dp[i][j - 1]);
//取左端点和取右端点
}
}
return dp[0][n - 1] >= 0;
}
}