


区间dp问题

java
class Solution {
public int getMoneyAmount(int n) {
int[][] dp = new int[n + 1][n + 1];
for (int i = n - 1; i >= 1; i--) {
dp[i][i + 1] = i;
for (int j = i + 2; j <= n; j++) {
dp[i][j] = Integer.MAX_VALUE;
for (int k = i + 1; k < j; k++) {
dp[i][j] = Math.min(dp[i][j],Math.max(dp[i][k - 1], dp[k + 1][j]) + k);
}
}
}
return dp[1][n];
}
}