LeetCode322.零钱兑换(一)

2024-06-19 13:12
文章标签 兑换 零钱 leetcode322

本文主要是介绍LeetCode322.零钱兑换(一),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在这里插入图片描述

LeetCode刷题记录

文章目录

    • 📜题目描述
    • 💡解题思路
    • C++代码


📜题目描述

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

计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,返回 -1 。

你可以认为每种硬币的数量是无限的。

示例1:

输入:coins = [1, 2, 5], amount = 11
输出:3 
解释:11 = 5 + 5 + 1

示例2:

输入:coins = [2], amount = 3
输出:-1

示例3:

输入:coins = [1], amount = 0
输出:0

提示:

  • 1 <= coins.length <= 12
  • 1 <= coins[i] <= 2^31 - 1
  • 0 <= amount <= 10^4

💡解题思路

amount为目标金额
我们定义一个[amount+1]大小的数组,dp[amount+1]

状态定义
dp[i]表示达到金额 i 所需要的最最少硬币枚数
每个状态所能加的钱数 只能是 coins 数组中的值
所有有些金额无法达到
在这里插入图片描述

coins = [1,2,5] ,amount = 11 为例
每个位置能走到 i + (one in coins) 位置,one in coins可以是 1、2、5

  • 如果目标位置没到达过,目标位置的值为当前位置+1
  • 如果目标位置到达过,目标位置的值 = min(目标位置当前值,当前位置+1)
  • 如果当前位置不可到达,continue

状态转移
前提i + coins[j] < length
dp[i + coins[j]] == -1 (即没有到达过此金额)
dp[i + coins[j]] = dp[i] +1
否则
dp[i + coins[j]] = min(dp[i+coins[j],dp[i]+1)

初始值
dp[0] = 0, 其余值初始化为 -1

返回结果
dp[amount] , 即为了凑成amount 最少需要的硬币枚数

C++代码

在这里插入图片描述

这篇关于LeetCode322.零钱兑换(一)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1075123

相关文章

代码随想录算法训练营Day44|322.零钱兑换、279.完全平方数、139.单词拆分

零钱兑换 322. 零钱兑换 - 力扣(LeetCode) 本题是完全背包问题 dp数组表示组成amount金额所需的最少硬币个数。 考虑dp数组的推导公式,由于是计算最少硬币的个数,所以需要考虑dp[i-coins[j]+1和dp[i]的较小值。所以dp[i] = min(dp[i-coins[j]]+1,dp[i]),其中i为遍历过程中的amout值,coins[j]为硬币的面值。

【代码随想录算法训练Day44】LeetCode 322.零钱兑换、LeetCode 279.完全平方数、LeetCode139.单词拆分

Day44 动态规划第六天 LeetCode 322.零钱兑换 dp数组的含义:装满容量为j的背包需要的最少物品数为dp[j] 递推公式:dp[j]=min(dp[j-coins[i]]+1,dp[j]) 初始化:dp[0]=0,dp[j]=INT_MAX 遍历顺序:个数问题与遍历顺序无关,都可以 class Solution {public:int coinChange(vector<i

代码随想录算法训练营第44天(py)| 动态规划 | 322. 零钱兑换、279.完全平方数、139.单词拆分

322. 零钱兑换 力扣链接 给你一个整数数组 coins ,表示不同面额的硬币;以及一个整数 amount ,表示总金额。 计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,返回 -1 。 你可以认为每种硬币的数量是无限的。 思路 每种硬币数量无限,是多重背包问题。 确定dp含义 凑到总金额为i的最少硬币个数为dp[i]确定递推公式 凑足总额为j -

【代码随想录】【算法训练营】【第44天】 [322]零钱兑换 [279]完全平方数 [139]单词拆分

前言 思路及算法思维,指路 代码随想录。 题目来自 LeetCode。 day 44,周四,坚持不住了~ 题目详情 [322] 零钱兑换 题目描述 322 零钱兑换 解题思路 前提: 思路: 重点: 代码实现 C语言 [279] 完全平方数 题目描述 279 完全平方数 解题思路 前提: 思路: 重点: 代码实现 C语言 [139] 单词拆分

【代码随想录算法训练营第四十三天|卡码网52.携带研究材料、18.零钱兑换II、377.组合总和Ⅳ、卡码网57.爬楼梯】

文章目录 卡码网52.携带研究材料518.零钱兑换II377.组合总和Ⅳ卡码网57.爬楼梯 卡码网52.携带研究材料 这题是完全背包问题,完全背包问题在01背包问题的基础上其实主要是三个不同,第一个是初始化的时候不能再和01背包一样对第一个物品让背包大小大于物品重量的时候全部初始化为物品价值,因为现在的物品可以无限放。第二个就是动态规划内部的循环推导的时候不用倒序而是正序了,因为

代码随想录算法训练营第四十三天 | 完全背包理论基础、518.零钱兑换II、377. 组合总和 Ⅳ、70. 爬楼梯 (进阶)

完全背包理论基础 题目链接:https://kamacoder.com/problempage.php?pid=1052 文档讲解:https://programmercarl.com/%E8%83%8C%E5%8C%85%E9%97%AE%E9%A2%98%E7%90%86%E8%AE%BA%E5%9F… 视频讲解:https://www.bilibili.com/video/BV1uK41

代码随想录算法训练营第四十三天|LeetCode518 零钱兑换Ⅱ、LeetCode377 组合总和Ⅳ

01背包与完全背包: 01背包与完全背包最大的区别在于01背包物品每个只能取一次而完全背包每个物品可以取无数次,这也就导致了我们内层for循环中的不同。具体体现为:因为01背包每个物品仅用一次,所以我们将背包从大到小(倒序)遍历;而完全背包是可以多次添加那么需要将背包从小到大(正序)遍历。 题1: 指路:518. 零钱兑换 II - 力扣(LeetCode) 思路与代码: 凑金币,典型的

算法训练 | 动态规划Part5 | 518.零钱兑换 II、377.组合总和 Ⅳ 、70.爬楼梯 (进阶)

目录 518. 零钱兑换 II 动态规划法 377. 组合总和 Ⅳ 动态规划法 70. 爬楼梯 (进阶) 动态规划法 518. 零钱兑换 II 题目链接:518. 零钱兑换 II - 力扣(LeetCode) 文章讲解:代码随想录 动态规划法 完全背包:01背包内嵌的循环是从大到小遍历,为了保证每个物品仅被添加一次。而完全背包的物品是可以添加多次的,所以要从小

代码随想录算法训练营第43天(py)| 动态规划 | 完全背包、518. 零钱兑换 II、377. 组合总和 Ⅳ、爬楼梯

完全背包 完全背包和01背包问题唯一不同的地方就是,每种物品有无限件。 有N件物品和一个最多能背重量为W的背包。第i件物品的重量是weight[i],得到的价值是value[i] 。每件物品都有无限个(也就是可以放入背包多次),求解将哪些物品装入背包里物品价值总和最大。 01背包内嵌的循环是从大到小遍历,为了保证每个物品仅被添加一次。 for(int i = 0; i < weight.siz

【做一道算一道】零钱兑换

零钱兑换 给你一个整数数组 coins ,表示不同面额的硬币;以及一个整数 amount ,表示总金额。 计算并返回可以凑成总金额所需的 最少的硬币个数 。如果没有任何一种硬币组合能组成总金额,返回 -1 。 你可以认为每种硬币的数量是无限的。 示例 1: 输入:coins = [1, 2, 5], amount = 11 输出:3 解释:11 = 5 + 5 + 1 示例 2: 输