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);;
    }
};
相关推荐
Anastasiozzzz3 分钟前
LeetCode Hot100 215. 数组中的第K个最大元素
数据结构·算法·leetcode
让我上个超影吧4 分钟前
【力扣76】最小覆盖子串
算法·leetcode·职场和发展
近津薪荼19 分钟前
优选算法——双指针5(单调性)
c++·学习·算法
2401_8576835426 分钟前
C++代码静态检测
开发语言·c++·算法
时艰.31 分钟前
JVM 垃圾收集器(G1&ZGC)
java·jvm·算法
2401_8384725131 分钟前
内存泄漏自动检测系统
开发语言·c++·算法
m0_706653231 小时前
基于C++的爬虫框架
开发语言·c++·算法
diediedei1 小时前
嵌入式数据库C++集成
开发语言·c++·算法
君义_noip1 小时前
洛谷 P3388 【模板】割点(割顶)
c++·算法·图论·信息学奥赛·csp-s
xie0510_1 小时前
string模拟实现
开发语言·c++·算法