【算法与数据结构】322、LeetCode零钱兑换

文章目录

所有的LeetCode题解索引,可以看这篇文章------【算法和数据结构】LeetCode题解

一、题目

二、解法

  思路分析:本题可以抽象成一个完全背包问题。

  • 第一步, d p j dpj dpj的含义。 d p j dpj dpj代表的是背包容量 j j j时,组成背包的最少物品数。
  • 第二步,递推公式。 d p j dpj dpj可以由 d p j − n u m s \[ i ] dpj-nums\[i] dpj−nums\[i]得出,在此基础上加上1即可。因为要去最小的组合数量,所有最终的递归公式变成 d p j = m a x ( d p j − n u m s \[ i ] , d p j ) dpj=max(dpj-nums\[i], dpj) dpj=max(dpj−nums\[i],dpj)。
  • 第三部,元素初始化。 d p 0 dp0 dp0初始化为0。因为有min函数的关系,动态数组的其他元素初始化应该为int类型的最大整数。
  • 第四部,递归顺序。本题无所谓组合和排列问题,所以先遍历物品后遍历背包容量还是先遍历背包容量后遍历物品都可以。
  • 第五步,打印结果。最终的dp数组会剩下可以由硬币组合成功的零钱,结果为其最小数量,直接返回;而不能组合出来的零钱结果为INT_MAX,我们返回-1。
      程序如下:
cpp 复制代码
class Solution {
public:
	int coinChange(vector<int>& coins, int amount) {
		vector<int> dp(amount + 1, INT_MAX);
		dp[0] = 0;
		for (int i = 0; i < coins.size(); i++) {    // 遍历物品
			for (int j = coins[i]; j <= amount; j++) {  // 遍历背包容量
				if (dp[j - coins[i]] != INT_MAX) {
					dp[j] = min(dp[j - coins[i]] + 1, dp[j]);
				}
			}
		}
		return dp[amount] == INT_MAX ? -1 : dp[amount];
	}
};

复杂度分析:

  • 时间复杂度: O ( n ∗ a m o u n t ) O(n*amount) O(n∗amount),n为coins数组长度。
  • 空间复杂度: O ( a m o u n t ) O(amount) O(amount)。

三、完整代码

cpp 复制代码
# include <iostream>
# include <vector>
using namespace std;

class Solution {
public:
	int coinChange(vector<int>& coins, int amount) {
		vector<int> dp(amount + 1, INT_MAX);
		dp[0] = 0;
		for (int i = 0; i < coins.size(); i++) {    // 遍历物品
			for (int j = coins[i]; j <= amount; j++) {  // 遍历背包容量
				if (dp[j - coins[i]] != INT_MAX) {
					dp[j] = min(dp[j - coins[i]] + 1, dp[j]);
				}
			}
		}
		return dp[amount] == INT_MAX ? -1 : dp[amount];
	}
};

int main() {
	//vector<int> coins = { 1, 2, 5 };
	vector<int> coins = { 2 };
	int amount = 3;
	Solution s1;
	int result = s1.coinChange(coins, amount);
	cout << result << endl;
	system("pause");
	return 0;
}

end

相关推荐
JieE2126 小时前
LeetCode 56. 合并区间|超清晰 JS 图解思路,面试高频区间题
javascript·算法·面试
Jack2014 小时前
HarmonyOS开发中错误处理策略:网络异常统一处理
算法
小小杨树16 小时前
读懂色彩:拍照调色不再难
算法·计算机视觉·配色
JieE2121 天前
LeetCode 226. 翻转二叉树|JS 递归超详细拆解,二叉树入门经典题
javascript·算法
JieE2121 天前
LeetCode 104. 二叉树的最大深度|递归思路超详细拆解
javascript·算法
vivo互联网技术2 天前
CVPR 2026 | 全新强化学习框架 BeautyGRPO:重塑真实人像
算法·大模型·cvpr·影像
Darling噜啦啦2 天前
列表转树算法深度解析:从 Map 到 Reduce 的两种实现,面试高频考点
数据结构·算法·面试
用户497863050732 天前
(一)小红的数组操作
算法·编程语言
怕浪猫2 天前
Electron 系列文章封面图
算法·架构·前端框架