LeetCode_322_零钱兑现
class Solution {
public:
int coinChange(vector<int>& coins, int amount) {
/*完全背包*/
// 下边这个公式表示一个一个硬币放进去,看哪种最小
// f(n) = min(f(n - c1), f(n - c2), ... f(n - cn)) + 1
// 初始化,题目问最小,这里定义成amount+1,f(n) >=amount则表明不能组合成功
int Max = amount + 1;
int dp[amount+1];
for(auto& e:dp){
e=amount + 1;
}
dp[0] = 0;
/*dp[i]表示总金额为i最少使用的硬币数目*/
for(int i = 1; i <= amount; i++) {
for(auto& e:coins) {
if (e <= i) {
dp[i] = min(dp[i], dp[i-e] + 1);
}
}
}
if (dp[amount] > amount) {
return -1;
} else {
return dp[amount];
}
}
};