难度:中等。
标签:广度优先搜索,动态规划,数组。
还想了半天,脑子秀逗了。
动态规划很简单。
正确解法:
class Solution {
public:
int coinChange(vector<int>& coins, int amount) {
int n = coins.size();
vector<int> dp(amount + 1, amount + 1);
dp[0] = 0;
for(int i = 1; i <= amount; ++i){
for(int j = 0; j < n; ++j){
if(i >= coins[j])dp[i] = min(dp[i], dp[i - coins[j]] + 1);
}
}
if(dp[amount] == amount + 1)return -1;
return dp[amount];
}
};
结果: