IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 开发测试 -> HNU软件能力实训4-8. 最少钱币数 -> 正文阅读

[开发测试]HNU软件能力实训4-8. 最少钱币数

写在前面

你好!欢迎来到我的博客,希望我的思路能够帮到你!

问题描述

这是一个古老而又经典的问题。用给定的几种钱币凑成某个钱数,一般而言有多种方式。例如:给定了 6 种钱币面值为 2、5、10、20、50、100,用来凑 15 元,可以用 5 个 2 元、1个 5 元,或者 3 个 5 元,或者 1 个 5 元、1个 10 元,等等。显然,最少需要 2 个钱币才能凑成 15 元。

你的任务就是,给定若干个互不相同的钱币面值,编程计算,最少需要多少个钱币才能凑成某个给出的钱数。

输入形式

输入可以有多个测试用例。每个测试用例的第一行是待凑的钱数值 M(1 <= M<= 2000,整数),接着的一行中,第一个整数 K(1 <= K <= 10)表示币种个数,随后是 K个互不相同的钱币面值 Ki(1 <= Ki <= 1000)。输入 M=0 时结束。

输出形式

每个测试用例输出一行,即凑成钱数值 M 最少需要的钱币个数。如果凑钱失败,输出“Impossible”。你可以假设,每种待凑钱币的数量是无限多的。

样例输入

15
6 2 5 10 20 50 100
1
1 2
0

样例输出

2
Impossible

解题思路

这是一道dp问题,dp问题的一大特点就是代码特别短。

dp问题可以分为两个部分,集合的表示及属性,集合的划分,对于这道题

集合:凑i元所需的硬币数

属性:最小值(常见的属性:max,min,数量)

集合的划分:我们可以以上一次使用的硬币作为划分的依据,对于i元,我们上次可使用的硬币是1,2,3,...,i元,但是前提是要有这样的硬币,所以可以遍历整个硬币数组,所以我们的状态转移方程为f[i]=min(f[i-w[j]]+1);

AC代码

#include<iostream>
#include<algorithm>
#include<cstring>
using namespace std;

const int N=15,M=2010,inf=0x3f3f3f3f;
int m,n;
int w[N];
int f[M];//凑i元需要的硬币数的最小值

int main()
{
    while(cin>>m,m)//多case,输入钱数
    {
    	//输入
        cin>>n;//输入硬币种类数
        for(int i=0;i<n;i++)
            cin>>w[i];//输入硬币
        
        //初始化
		memset(f,inf,sizeof f);//初始化f数组,将其置为inf
        f[0]=0;//凑0元当然需要0个硬币
        
        //dp
		for(int i=1;i<=m;i++)//遍历所有的钱数
            for(int j=0;j<n;j++)//遍历所有的硬币
                if(i>=w[j])//如果钱数大于硬币面值
                    f[i]=min(f[i],f[i-w[j]]+1);//更新
        
        //输出
		if(f[m]==inf) cout<<"Impossible"<<endl;//说明不存在方法凑出对应面额
        else cout<<f[m]<<endl;
    }
    system("pause");
    return 0;
}

写在最后

如果代码有任何问题,欢迎评论或者私信斧正。如果内容对对你有启发,不妨点个赞吧

  开发测试 最新文章
pytest系列——allure之生成测试报告(Wind
某大厂软件测试岗一面笔试题+二面问答题面试
iperf 学习笔记
关于Python中使用selenium八大定位方法
【软件测试】为什么提升不了?8年测试总结再
软件测试复习
PHP笔记-Smarty模板引擎的使用
C++Test使用入门
【Java】单元测试
Net core 3.x 获取客户端地址
上一篇文章      下一篇文章      查看所有文章
加:2021-08-29 09:39:58  更:2021-08-29 09:40:04 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年5日历 -2024/5/10 14:54:24-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码