本文主要是介绍acwing——656.钞票和硬币,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
656.钞票和硬币
读取一个带有两个小数位的浮点数,这代表货币价值。
在此之后,将该值分解为多种钞票与硬币的和,每种面值的钞票和硬币使用数量不限,要求使用的钞票和硬币的数量尽可能少。
钞票的面值是100,50,20,10,5,2。
硬币的面值是1,0.50,0.25,0.10,0.05和0.01。
输入格式
输入一个浮点数N。
输出格式
参照输出样例,输出每种面值的钞票和硬币的需求数量。
数据范围
0≤N≤1000000.000≤N≤1000000.00
输入样例:
576.73
输出样例:
NOTAS:
5 nota(s) de R$ 100.00
1 nota(s) de R$ 50.00
1 nota(s) de R$ 20.00
0 nota(s) de R$ 10.00
1 nota(s) de R$ 5.00
0 nota(s) de R$ 2.00
MOEDAS:
1 moeda(s) de R$ 1.00
1 moeda(s) de R$ 0.50
0 moeda(s) de R$ 0.25
2 moeda(s) de R$ 0.10
0 moeda(s) de R$ 0.05
3 moeda(s) de R$ 0.01
思路:
可以先将输入的浮点数 n 乘以 100 转化为整数比较方便。
程序代码:
#include<iostream>
using namespace std;
int main()
{double n;int a[6] = {100,50,20,10,5,2};int b[6] = {100,50,25,10,5,1};cin>>n;int m = n * 100;printf("NOTAS:\n");for (int i=0;i<6;i++){printf("%d nota(s) de R$ %.2lf\n", m/(a[i]*100), (double)a[i]);m %= a[i] * 100;}printf("MOEDAS:\n");for (int i=0;i<6;i++){printf("%d moeda(s) de R$ %.2lf\n", m/b[i], b[i]/100.0);m %= b[i];}return 0;
}
这篇关于acwing——656.钞票和硬币的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!