思路:
与题目279. 完全平方数-CSDN博客类似。从1开始计算每一个金额,对于金额i,从小到大遍历每一个coin,dp[i] = Math.max(dp[i], dp[i - conis[j]] + 1),1表示使用了一次coins[j]。
还可以从多重背包的角度考虑。
代码:
class Solution {
public int coinChange(int[] coins, int amount) {
int n = coins.length;
Arrays.sort(coins);
int[] dp = new int[amount + 1];
for(int i = 1; i <= amount; i++) {
dp[i] = Integer.MAX_VALUE;
for(int j = 0; j < n && i - coins[j] >= 0; j++) {
if(dp[i - coins[j]] != Integer.MAX_VALUE)
dp[i] = Math.min(dp[i], dp[i - coins[j]] + 1);
}
}
return dp[amount] == Integer.MAX_VALUE ? -1 : dp[amount];
}
}