某国由于互联网还不普及,超市售货员只能使用现金找零。1元、 2元、5元、10元硬币是找零货币单位,售货员每种币值数量都是足够充足找零。当某个顾客用大额现 购物后,需要找零金额为输入元数(例:输入37元)。请设计一个程序实现找零,输出总的找零方法数(例:输出160种)。用c++写

时间: 2024-03-24 14:36:54 浏览: 27
好的,以下是使用 C++ 实现的代码: ```cpp #include <iostream> #include <vector> using namespace std; int main() { int n = 4; // 硬币种类数 int m; // 需要找零的金额数 cin >> m; vector<int> coin = {0, 1, 2, 5, 10}; // 硬币面值 vector<vector<int>> dp(n+1, vector<int>(m+1, 0)); // 初始化状态数组 for (int i = 1; i <= n; i++) { dp[i][0] = 1; // 边界条件 for (int j = 1; j <= m; j++) { for (int k = 0; k <= j/coin[i]; k++) { dp[i][j] += dp[i-1][j-k*coin[i]]; // 转移方程 } } } cout << dp[n][m] << endl; // 输出结果 return 0; } ``` 其中,状态数组 dp[i][j] 表示使用前 i 种硬币,凑出 j 元的总共方法数;coin 是硬币面值的数组,其中 coin[i] 表示第 i 种硬币的面值;n 表示硬币种类数。程序运行时,会从输入流中读取需要找零的金额数 m,然后使用动态规划算法计算出凑出 m 元的总共方法数,最后输出结果。 注意,由于 C++ 中数组下标从 0 开始,因此在初始化硬币面值数组 coin 时,需要在开头加上一个 0,以保证 coin[i] 表示第 i 种硬币的面值。

相关推荐

题目 B: 货币套利 时间限制:1Sec 内存限制:64MB 提交:36 解决:4 [提交] [状态] 题目描述 套利是利用多国之间货币兑换率的差异,把某国单位币值经多种货币兑换后实现升值的牟利方式。例如,假设 1 美元能兑 0.5 英镑,1 英镑能兑换 10.0 法郎,1 法郎能兑换 0.21 美元,那么,通过货币转换,聪明的商人可以使得 1 美元经兑换变成 1*0.5*10.0*0.21=1.05 美元,获利 5%。 你的工作是编写一个程序,以货币兑换率的列表作为输入,然后确定是否可能套利。 输入 多组测试数据。每组数据: 第一行一个整数 n(1≤n≤30,n=0 时表示输入结束),表示不同货币的数量。 接下来 n 行,每行一个字符串,表示一种货币的名称。字符串仅由大小写字母组成,长度不超过 30 个字符。 接下来一行一个整数 m,表示有 m 对货币兑换率。 最后 m 行,每行三项数据,分别为一个字符串 ci,一个实数 rij(0<rij<1000,3 位小数),一个字符串 cj。表示货币 ci 兑换货币 cj 的兑换率为 rij --- 即 1 单位 ci 能兑换成 rij 单位 cj。该货币兑换是单向的,即 "ci rij cj" 不能说明 cj 可以按 rij 或 1/rij 兑换为 ci。这里没有列出兑换率的两种货币是无法直接相互兑换的。 两组数据之间由一个空行分隔。 输出 每组数据输出一行,格式参考样例输出结果。如果可以套利,结果中包含 "Yes",否则包含 "No"。

最新推荐

recommend-type

基于SIR模型对某市新型冠状病毒疫情趋势的分析(matlab)

以前写的课设,数据是2020年6月-12月的。包含代码和数据集。 因为需要清理文档,就上传做个记录
recommend-type

农产品定价问题数学建模

某国政府要为其牛奶、奶油和奶酪等奶制品定价。所有这些产品都直接或间接的来自国家的原奶生产。原奶首先要分离脂肪两种组合,去掉生产和农场消耗的产品的部分后,余下的共有60万吨脂肪和70万吨奶粉,可用于生产牛奶...
recommend-type

SAP财务系统集团公司处理

在SAP财务系统中存在三大类会计科目...其中运营会计科目表是记账必须的会计科目表,集团会计科目表是集团出具合并会计报表使用的会计科目表,国家会计科目表是为了满足某国要求,出具的符合该国会计准则要求的科目表。
recommend-type

微信小程序-番茄时钟源码

微信小程序番茄时钟的源码,支持进一步的修改。番茄钟,指的是把工作任务分解成半小时左右,集中精力工作25分钟后休息5分钟,如此视作种一个“番茄”,而“番茄工作法”的流程能使下一个30分钟更有动力。
recommend-type

激光雷达专题研究:迈向高阶智能化关键,前瞻布局把握行业脉搏.pdf

电子元件 电子行业 行业分析 数据分析 数据报告 行业报告
recommend-type

zigbee-cluster-library-specification

最新的zigbee-cluster-library-specification说明文档。
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

实现实时数据湖架构:Kafka与Hive集成

![实现实时数据湖架构:Kafka与Hive集成](https://img-blog.csdnimg.cn/img_convert/10eb2e6972b3b6086286fc64c0b3ee41.jpeg) # 1. 实时数据湖架构概述** 实时数据湖是一种现代数据管理架构,它允许企业以低延迟的方式收集、存储和处理大量数据。与传统数据仓库不同,实时数据湖不依赖于预先定义的模式,而是采用灵活的架构,可以处理各种数据类型和格式。这种架构为企业提供了以下优势: - **实时洞察:**实时数据湖允许企业访问最新的数据,从而做出更明智的决策。 - **数据民主化:**实时数据湖使各种利益相关者都可
recommend-type

解释minorization-maximization (MM) algorithm,并给出matlab代码编写的例子

Minorization-maximization (MM) algorithm是一种常用的优化算法,用于求解非凸问题或含有约束的优化问题。该算法的基本思想是通过构造一个凸下界函数来逼近原问题,然后通过求解凸下界函数的最优解来逼近原问题的最优解。具体步骤如下: 1. 初始化参数 $\theta_0$,设 $k=0$; 2. 构造一个凸下界函数 $Q(\theta|\theta_k)$,使其满足 $Q(\theta_k|\theta_k)=f(\theta_k)$; 3. 求解 $Q(\theta|\theta_k)$ 的最优值 $\theta_{k+1}=\arg\min_\theta Q(
recommend-type

JSBSim Reference Manual

JSBSim参考手册,其中包含JSBSim简介,JSBSim配置文件xml的编写语法,编程手册以及一些应用实例等。其中有部分内容还没有写完,估计有生之年很难看到完整版了,但是内容还是很有参考价值的。