力扣题解(零钱兑换II)

518. 零钱兑换 II

给你一个整数数组 coins 表示不同面额的硬币,另给一个整数 amount 表示总金额。

请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额,返回 0

假设每一种面额的硬币有无限个。

题目数据保证结果符合 32 位带符号整数。

思路:

对一堆数字中选取某几个,且每个数字可以重复出现,因此是完全背包问题。

dp[i][j]表示前i个字符组合是j的所有组合数。

dp[i][j]=dp[i-1][j]+dp[i][j-coins[i]]。(此处用+的原因是要求的是所有可能的组合数)

初始化:

i为0的时候,仅有j同样为0才有可能有组合数,因此其余均为0.

当j为0的时候,对i任意取值,都存在一个数都不取结果为0的情况,因此dp[i][0]为1.

复制代码
class Solution {
public:
    int change(int amount, vector<int>& coins) {
      int n=coins.size();
     int INF=0x3f3f3f3f;
     vector<vector<int>>dp(n+1,vector<int>(amount+1,0));
     for(int i=0;i<=n;i++)
     {
        dp[i][0]=1;
     }
     coins.insert(coins.begin(),0);
     for(int i=1;i<=n;i++)
     {
        for(int j=1;j<=amount;j++)
        {
            dp[i][j]=dp[i-1][j];
            if(j-coins[i]>=0)
            {
              //  cout<<i<<j-coins[i]<<" ||";
            
              dp[i][j]+=dp[i][j-coins[i]];
            
            }
        }
     }
     return dp[n][amount]==INF?0:dp[n][amount];


    }
    
};
相关推荐
样例过了就是过了几秒前
LeetCode热题100 环形链表
算法·leetcode·链表
努力学算法的蒟蒻5 分钟前
day95(2.24)——leetcode面试经典150
算法·leetcode·面试
ZPC82109 分钟前
window 下使用docker
人工智能·python·算法·机器人
DaisyMosuki10 分钟前
个人实现大数加减乘(高精度加减乘)
算法·高精度·大数
郭逍遥13 分钟前
[Godot] 通过AABB包围盒和射线法检测碰撞
算法·游戏引擎·godot
大黄说说14 分钟前
解锁 .NET 性能极限:深入解析 Span 与零拷贝内存艺术
java·数据结构·算法
知识即是力量ol16 分钟前
深入理解 Snowflake 雪花算法:原理、本质、趋势递增问题与分布式顺序困境全解析
java·分布式·算法·雪花算法·snowflake·全局唯一id·分布式id生成器
啊阿狸不会拉杆17 分钟前
《计算机视觉:模型、学习和推理》第 11 章-链式模型和树模型
人工智能·学习·算法·机器学习·计算机视觉·hmm·链式模型
二年级程序员26 分钟前
一篇文章掌握“树”(上)
c语言·数据结构·算法
薛定e的猫咪27 分钟前
【Bayesian Analysis 2023】大数据背景下的分布式贝叶斯模型选择
大数据·分布式·算法·数学建模