leetcode518. 零钱兑换 II

在这里插入图片描述

一:题目

在这里插入图片描述

二:上码

class Solution {
public:
    /**
        思路:1.分析题意
               这个满足答案的结果有很多种,所以我们可以用动态规划去做,那么题意中我们可以知道的是我们是可以输入一种面值
                的时候,我们是可以重复输入的,那么这就是背包类型中的完全背包了
            2.动态规划5步走
              1>:确定dp数组以及下标的含义
                    dp[j] 表示背包容量为j的时候(这里也就是指的是面值),最多有dp[j]种装法
              2>:确定dp数组的状态递推公式
                    dp[j] = dp[j] + dp[j-coins[i]];
                    这里我们需要用到累加,因为我们是统计有多种装法,比如面值为5,装入2的时候  还剩下3 那么我们
                    直接加上dp[3]时候的装法;就是我们当前的装法
              3>:确定dp数组的初始化
                    当我们金额总数为0的时候,也就是我们的j == 0的时候,我们dp[j]最多有1种装法
                    或者从代码的逻辑角度推理,我们在遍历第一个面值的时候,我们是需要第一个统计dp[j]赋初值的
                    否则我们的后续计算是无法进行的
              4>:确定dp数组的遍历顺序
                    这是完全背包,所以是允许重复的装入物品的,所以我们是正序遍历的
              5>:举例验证


    */

    int change(int amount, vector<int>& coins) {
        
        vector<int> dp(amount+1,0);
        dp[0]=1;
        
        for(int i = 0; i < coins.size(); i++) {
            for(int j = coins[i]; j <=amount; j++){//这里从coins[i]开始遍历背包  因为我们的背包容量至少也是需要
                 dp[j] += dp[j - coins[i]];                                  //coins[i]的
            }
        }   

        return dp[amount];
    }
};

在这里插入图片描述

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

天天向上的菜鸡杰!!

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值