这道题的坑点在于直接使用浮点型计算会由于精度损失导致输出结果偏小,因此要先把浮点型转换为整型数据进行计算,问题如下:
解法如下:
#include<cstdio>
int main()
{
double m;
scanf("%lf",&m);
int n = m*100;//,由于除法自动取整,直接用浮点型计算会错误,因此先将浮点型转为整型
printf("NOTAS:\n");
printf("%d nota(s) de R$ 100.00\n",n/10000);n %= 10000;
printf("%d nota(s) de R$ 50.00\n",n/5000);n %= 5000;
printf("%d nota(s) de R$ 20.00\n",n/2000);n %= 2000;
printf("%d nota(s) de R$ 10.00\n",n/1000);n %= 1000;
printf("%d nota(s) de R$ 5.00\n",n/500);n %= 500;
printf("%d nota(s) de R$ 2.00\n",n/200);n %= 200;
printf("MOEDAS:\n");
printf("%d moeda(s) de R$ 1.00\n",n/100);n%=100;
printf("%d moeda(s) de R$ 0.50\n",n/50);n%=50;
printf("%d moeda(s) de R$ 0.25\n",n/25);n%=25;
printf("%d moeda(s) de R$ 0.10\n",n/10);n%=10;
printf("%d moeda(s) de R$ 0.05\n",n/5);n%=5;
printf("%d moeda(s) de R$ 0.01\n",n/1);n%=1;
return 0;
}