leetcode-518-dp-背包
/**
* <p>给你一个整数数组 <code>coins</code> 表示不同面额的硬币,另给一个整数 <code>amount</code> 表示总金额。</p>
*
* <p>请你计算并返回可以凑成总金额的硬币组合数。如果任何硬币组合都无法凑出总金额,返回 <code>0</code> 。</p>
*
* <p>假设每一种面额的硬币有无限个。 </p>
*
* <p>题目数据保证结果符合 32 位带符号整数。</p>
*
* <p> </p>
*
* <ul>
* </ul>
*
* <p><strong>示例 1:</strong></p>
*
* <pre>
* <strong>输入:</strong>amount = 5, coins = [1, 2, 5]
* <strong>输出:</strong>4
* <strong>解释:</strong>有四种方式可以凑成总金额:
* 5=5
* 5=2+2+1
* 5=2+1+1+1
* 5=1+1+1+1+1
* </pre>
*
* <p><strong>示例 2:</strong></p>
*
* <pre>
* <strong>输入:</strong>amount = 3, coins = [2]
* <strong>输出:</strong>0
* <strong>解释:</strong>只用面额 2 的硬币不能凑成总金额 3 。
* </pre>
*
* <p><strong>示例 3:</strong></p>
*
* <pre>
* <strong>输入:</strong>amount = 10, coins = [10]
* <strong>输出:</strong>1
* </pre>
*
* <p> </p>
*
* <p><strong>提示:</strong></p>
*
* <ul>
* <li><code>1 <= coins.length <= 300</code></li>
* <li><code>1 <= coins[i] <= 5000</code></li>
* <li><code>coins</code> 中的所有值 <strong>互不相同</strong></li>
* <li><code>0 <= amount <= 5000</code></li>
* </ul>
* <div><div>Related Topics</div><div><li>数组</li><li>动态规划</li></div></div><br><div><li>👍 860</li><li>👎 0</li></div>
*/
//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
public int change(int amount, int[] coins) {
int n = coins.length;
//前n个硬币 构成amount
int[][] dp = new int[n + 1][amount + 1];
for (int i = 0; i <= n; i++) {
dp[i][0] = 1;
}
//当前等于 上一个结果个数+【当前面纸硬币】【凑成的金额】
for (int i = 1; i <= n; i++) {
for (int j = 1; j <= amount; j++) {
if (j - coins[i - 1] >= 0) {
dp[i][j] = dp[i - 1][j] + dp[i][j - coins[i - 1]];
} else {
dp[i][j] = dp[i - 1][j];
}
}
}
return dp[n][amount];
}
}
//leetcode submit region end(Prohibit modification and deletion)
不恋尘世浮华,不写红尘纷扰
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
2021-07-07 Lc_209长度最小的子数组
2020-07-07 基于链表实现LRU缓存淘汰算法