用c++完成以下问题:蒜头君最近在设计一款找钱系统,但它设计的系统比较奇葩。假如有 n 种硬币,每种硬币面值用 a 表示,并且数量不限。该系统会根据你要找的金额 m,从而找到最少使用硬币的数量以及该数量下的方案总数。

时间: 2023-05-11 13:05:01 浏览: 142
这个问题可以使用动态规划来解决。首先定义一个数组 dp,其中 dp[i] 表示找到金额 i 所需的最少硬币数量。初始化 dp[0] 为 0,其余元素为正无穷大。然后遍历硬币面值数组 a,对于每个面值 j,更新 dp[i] = min(dp[i], dp[i-j]+1)。最后 dp[m] 就是找到金额 m 所需的最少硬币数量。方案总数可以通过类似的动态规划思路求解,定义一个数组 count,其中 count[i] 表示找到金额 i 所需的最少硬币数量下的方案总数。初始化 count[0] 为 1,其余元素为 0。然后遍历硬币面值数组 a,对于每个面值 j,更新 count[i] += count[i-j]。最后 count[m] 就是找到金额 m 所需的最少硬币数量下的方案总数。以下是 C 代码实现: ```c #include <stdio.h> #include <limits.h> #define MAX_N 100 #define MAX_M 10000 int n, m; int a[MAX_N]; int dp[MAX_M+1]; int count[MAX_M+1]; int main() { scanf("%d%d", &n, &m); for (int i = 0; i < n; i++) { scanf("%d", &a[i]); } for (int i = 1; i <= m; i++) { dp[i] = INT_MAX; count[i] = 0; } dp[0] = 0; count[0] = 1; for (int i = 0; i < n; i++) { for (int j = a[i]; j <= m; j++) { if (dp[j-a[i]] != INT_MAX && dp[j-a[i]]+1 < dp[j]) { dp[j] = dp[j-a[i]]+1; count[j] = count[j-a[i]]; } else if (dp[j-a[i]] != INT_MAX && dp[j-a[i]]+1 == dp[j]) { count[j] += count[j-a[i]]; } } } printf("%d %d\n", dp[m], count[m]); return 0; } ```

最新推荐

recommend-type

C++ 学生成绩管理系统设计报告书

个人课程设计报告书(内含源码) 内含4个类,各自具有其属性和行为。 基本实现了: (1)学生基本信息、考试科目及成绩的信息录入。 (2)已有学生信息的显示。 (3)学生基本信息的读取和保存输入数据等功能 (4)学生基本...
recommend-type

C++学校人员信息管理系统课程设计.doc

一个用C++写的学校人员管理系统,适合大一大二的课程设计,里面运用到了链表、文件读写等一些C++基本语法操作
recommend-type

操作系统课程设计:司机与售票员源代码.docx

操作系统结课的课程设计,题目为“实现司机与售票员P、V操作的同步与互斥”,此处贴上源代码,可以用codeblocks运行得到相应结果
recommend-type

诊所信息管理系统C++课程设计报告.doc

模拟诊所信息管理系统就是对存储患者信息以及医生信息在个人PC上的编程实现。本系统采用了用户身份的注册、登陆、增加信息、查询信息、帐单信息以及统计所有患者的总费用等功能。并分析在现实生活中遇到的问题并得到...
recommend-type

某景点门票销售管理系统数据库系统设计

景点门票销售管理系统,其实现功能主要是景点售票、退票、查询、统计及票务管理等,同时还可以对优惠活动及门票类型进行设置。使售票员操作简单,便于理解。该系统能够实现景点售票管理的系统化、规范化和自动化;...
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

【实战演练】MATLAB用遗传算法改进粒子群GA-PSO算法

![MATLAB智能算法合集](https://static.fuxi.netease.com/fuxi-official/web/20221101/83f465753fd49c41536a5640367d4340.jpg) # 2.1 遗传算法的原理和实现 遗传算法(GA)是一种受生物进化过程启发的优化算法。它通过模拟自然选择和遗传机制来搜索最优解。 **2.1.1 遗传算法的编码和解码** 编码是将问题空间中的解表示为二进制字符串或其他数据结构的过程。解码是将编码的解转换为问题空间中的实际解的过程。常见的编码方法包括二进制编码、实数编码和树形编码。 **2.1.2 遗传算法的交叉和
recommend-type

openstack的20种接口有哪些

以下是OpenStack的20种API接口: 1. Identity (Keystone) API 2. Compute (Nova) API 3. Networking (Neutron) API 4. Block Storage (Cinder) API 5. Object Storage (Swift) API 6. Image (Glance) API 7. Telemetry (Ceilometer) API 8. Orchestration (Heat) API 9. Database (Trove) API 10. Bare Metal (Ironic) API 11. DNS
recommend-type

JSBSim Reference Manual

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