LeetCode 322. Coin Change 动态规划

作者: Terence_F | 来源:发表于2016-08-10 17:30 被阅读329次

Coin Change
给定一组硬币和一个目标金额,返回最少用几个硬币能凑出目标金额,如果不能返回-1。

数组dp用来记录能凑出从 1 到 amount最少的硬币数量

class Solution {
public:
    int coinChange(vector<int>& coins, int amount) {
        vector<int> dp(amount + 1, amount + 1);
        dp[0] = 0;
        for (int i = 1; i <= amount; i++) {
            for (int j = 0; j < coins.size(); j++) {
                if (coins[j] <= i) {
                    // +1 硬币数量加一
                    dp[i] = min(dp[i - coins[j]] + 1, dp[i]);
                }
            }
        }
        return dp.back() > amount ? -1 : dp.back();
    }
};

相关文章

网友评论

    本文标题:LeetCode 322. Coin Change 动态规划

    本文链接:https://www.haomeiwen.com/subject/pqsjsttx.html