leetcode:322. 零钱兑换[完全背包]

学习要点

  1. 完全背包组合问题

题目链接

322. 零钱兑换 - 力扣(LeetCode)

题目描述

解法:完全背包组合

cpp 复制代码
class Solution {
public:
    int coinChange(vector<int>& coins, int amount) {
        // dp[j] = min(dp[j],dp[j - nums[i]] + 1)要讨论
        // 初始化
        vector<uint64_t> dp(amount+1,-1);
        dp[0] = 0;
        for(int i = 0;i<coins.size();i++)
        {
            for(int j = 0;j<=amount;j++)
            {
                if(j >= coins[i])
                {
                    int a = dp[j]; 
                    int b = dp[j - coins[i]];
                    int c;
                    if(b == -1)
                    {
                        c = -1;
                    }
                    else
                    {
                        c = b + 1;
                    }
                    if( a == -1)
                    {
                        dp[j] = c;
                    }
                    else if( c == -1)
                    {
                        dp[j] = a;
                    }
                    else
                    {
                        dp[j] = min(a,c);
                    }

                }
            }
        }
        return dp[amount];
    }
};
相关推荐
2202_756749696 分钟前
02 基于sklearn的机械学习-KNN算法、模型选择与调优(交叉验证、朴素贝叶斯算法、拉普拉斯平滑)、决策树(信息增益、基尼指数)、随机森林
python·算法·决策树·随机森林·机器学习·sklearn
ATaylorSu9 分钟前
经典算法之美:冒泡排序的优雅实现
开发语言·笔记·学习·算法
菜鸡nan1 小时前
23th Day| 39.组合总和,40.组合总和II,131.分割回文串
算法·leetcode·职场和发展
冷月葬花~1 小时前
day37 卡码网52. 携带研究材料 力扣518.零钱兑换II 力扣377. 组合总和 Ⅳ 卡码网57. 爬楼梯
算法
qq_513970441 小时前
力扣 hot100 Day63
数据结构·算法·leetcode
lifallen1 小时前
AbstractExecutorService:Java并发核心模板解析
java·开发语言·数据结构·算法
神器阿龙1 小时前
排序算法-归并排序
数据结构·算法·排序算法
遇见尚硅谷1 小时前
# C语言:20250730学习(二级指针)
c语言·学习·算法
Ashlee_code1 小时前
北极圈金融科技革命:奥斯陆证券交易所的绿色跃迁之路 ——从Visma千倍增长到碳信用衍生品,解码挪威资本市场的技术重构
科技·算法·金融·重构·架构·系统架构·区块链
我是why的狗2 小时前
赵义弘-----补题报告
算法·排序算法