力扣题解(零钱兑换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];


    }
    
};
相关推荐
gfdhy2 小时前
【c++】哈希算法深度解析:实现、核心作用与工业级应用
c语言·开发语言·c++·算法·密码学·哈希算法·哈希
Warren982 小时前
Python自动化测试全栈面试
服务器·网络·数据库·mysql·ubuntu·面试·职场和发展
百***06012 小时前
SpringMVC 请求参数接收
前端·javascript·算法
一个不知名程序员www3 小时前
算法学习入门---vector(C++)
c++·算法
云飞云共享云桌面3 小时前
无需配置传统电脑——智能装备工厂10个SolidWorks共享一台工作站
运维·服务器·前端·网络·算法·电脑
福尔摩斯张3 小时前
《C 语言指针从入门到精通:全面笔记 + 实战习题深度解析》(超详细)
linux·运维·服务器·c语言·开发语言·c++·算法
橘颂TA3 小时前
【剑斩OFFER】算法的暴力美学——两整数之和
算法·leetcode·职场和发展
Dream it possible!4 小时前
LeetCode 面试经典 150_二叉搜索树_二叉搜索树的最小绝对差(85_530_C++_简单)
c++·leetcode·面试
xxxxxxllllllshi4 小时前
【LeetCode Hot100----14-贪心算法(01-05),包含多种方法,详细思路与代码,让你一篇文章看懂所有!】
java·数据结构·算法·leetcode·贪心算法
前端小L4 小时前
图论专题(二十二):并查集的“逻辑审判”——判断「等式方程的可满足性」
算法·矩阵·深度优先·图论·宽度优先