当前位置: 首页 > news >正文

Leetcode:322. 零钱兑换(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

实现代码与解析:

动态规划(完全背包):

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], dp[j - coins[i]] + 1);}}}if(dp[amount] == INT_MAX) return -1;return dp[amount];}
};

原理思路:

        此题和Leetcode:474. 一和零(C++)_Cosmoshhhyyy的博客-CSDN博客很像,但是区别呢,就是此题求的是最小物品数,dp数组的含义就是装满背包用的最少硬币个数,对于dp数组的初始化,就是非零下标都取最大INT_MAX,因为我们后面要 dp[j] = min(dp[j], dp[j - coins[i]] + 1) 进行比较,如果都取 0 ,那么取 min 的时候就都取 0 了,显然是不对的,初始化为最大才能取到小值,当然  0 下标还是为 0 的,之后就是完全背包遍历了,最后如果dp数组还为初值,说明不能装满,则返回 -1。

http://www.lryc.cn/news/1693.html

相关文章:

  • C经典小游戏之扫雷
  • 第十节 使用设备树插件实现RGB 灯驱动
  • 【LeetCode】公交路线 [H](宽度优先遍历)
  • 报表生成器 FastReport .Net 用户指南 2023(十):Band的属性
  • DAMA数据管理知识体系指南之文档和内容管理
  • C++入门:数据结构
  • C语言实现烟花表白,内含源码!!
  • 虚拟机安装CentOS 7(带界面)
  • Java测试——selenium具体操作
  • 电子器件系列32:逻辑与门芯片74LS11
  • LeetCode-101. 对称二叉树
  • 使用intlinprog求解指派问题MATLAB代码分享
  • Spark On YARN时指定Python版本
  • [数据库]库的增删改查
  • Wine零知识学习1 —— 介绍
  • 设计模式--建造者模式 builder
  • 终于周末啦,继续来总结一下Python的一些知识点啦
  • CUDA By Example(八)——流
  • 02- pandas 数据库 (数据库)
  • less常用语法总结
  • DHCP Relay中继实验
  • “1+1>2”!《我要投资》与天际汽车再度“双向奔赴”!
  • 【分享】订阅金蝶KIS集简云连接器同步OA付款审批数据至金蝶KIS
  • dubbo服务消费
  • Python调用API接口,实现人脸识别
  • 2月10日刷题总结
  • C++学习/温习:新型源码学编程(三)
  • 阿里云ecs服务器搭建CTFd(ubuntu20)
  • 视频号小店新订单如何实时同步企业微信
  • ag-Grid Enterprise