322力扣:零钱兑换

DP:

cpp 复制代码
class Solution {
public:
    int coinChange(vector<int>& coins, int amount) {
        int n=coins.size();
        vector<int> dp(amount+1,-1);
        dp[0]=0;
        for(int i=1;i<=amount;i++){
            for(int j=0;j<n;j++){
                if(i-coins[j]>=0 && dp[i-coins[j]]>=0){
                    int res=dp[i-coins[j]]+1;
                    if(dp[i]==-1 || dp[i]>res)
                    dp[i]=res;
                }
            }
        }
        return dp[amount];
    }
};

记忆化与回溯:

cpp 复制代码
class Solution {
public:
    int coinChange(vector<int>& coins, int amount) {
        vector<int> count(amount+1,0);
        function<int(int)> dfs=[&](int amount){
            int Min=INT_MAX;
            if(amount==0) return 0;
            if(amount<0) return -1;
            if(count[amount]!=0) return count[amount];
            for(auto num:coins){
                if(dfs(amount-num)==-1) continue;
                if(dfs(amount-num)<Min)
                Min=dfs(amount-num)+1;
            }
            count[amount]=Min==INT_MAX?-1:Min;
            return count[amount];
        };
        return dfs(amount);;
    }
};
相关推荐
佩奇大王几秒前
P674 三羊献瑞
算法·深度优先·图论
发疯幼稚鬼42 分钟前
大整数乘法运算
c语言·算法
宵时待雨1 小时前
C++笔记归纳17:哈希
数据结构·c++·笔记·算法·哈希算法
问好眼1 小时前
《算法竞赛进阶指南》0x05 排序-1.电影
c++·算法·排序·信息学奥赛
CoderCodingNo1 小时前
【GESP】C++八级考试大纲知识点梳理 (6) 图论算法:最小生成树与最短路
c++·算法·图论
DeepModel1 小时前
【特征选择】嵌入法(Embedded)
人工智能·python·深度学习·算法
今儿敲了吗2 小时前
算法复盘——前缀和
笔记·学习·算法
ulias2122 小时前
智能指针简述
开发语言·c++·算法
寻寻觅觅☆2 小时前
东华OJ-基础题-58-素数表(C++)
开发语言·c++·算法
AI成长日志2 小时前
【强化学习专栏】深度拆解:多智能体强化学习核心理论与工程实践
算法