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];
    }
};
相关推荐
初晴や22 分钟前
【C++】图论:基础理论与实际应用深入解析
c++·算法·图论
李泽辉_22 分钟前
深度学习算法学习(五):手动实现梯度计算、反向传播、优化器Adam
深度学习·学习·算法
李泽辉_38 分钟前
深度学习算法学习(一):梯度下降法和最简单的深度学习核心原理代码
深度学习·学习·算法
꧁Q༒ོγ꧂41 分钟前
算法详解---大纲
算法
hqiangtai43 分钟前
Android 高级专家技术能力图谱
android·职场和发展
m0_603888711 小时前
Scaling Trends for Multi-Hop Contextual Reasoning in Mid-Scale Language Models
人工智能·算法·ai·语言模型·论文速览
Xの哲學1 小时前
Linux io_uring 深度剖析: 重新定义高性能I/O的架构革命
linux·服务器·网络·算法·边缘计算
comli_cn1 小时前
残差链接(Residual Connection)
人工智能·算法
Aaron15881 小时前
基于VU13P在人工智能高速接口传输上的应用浅析
人工智能·算法·fpga开发·硬件架构·信息与通信·信号处理·基带工程