人民币问题

本文介绍了一个使用C语言实现的功能,该功能可以计算组成任意给定金额所需的最少纸币数量。通过递减的方式,从最大面额开始计算,直至最小面额,确保了使用的纸币数量最少。

人民币问题

编写一个函数计算金额"X"需要多少张面值为n元的纸币。在主函数中输入一个金额值,调用该函数,计算组成该金额最少需要多少张纸币。
注:人民币面值不包括角和分 有1元、2元,5元,10元、20元、50元、100元。 

#include <stdio.h>
void main()
{
    int i, j, k,tmp=0,total=0;
    int money[7] = {100,50,20,10,5,2,1};
    int howEnt[7];

    scanf("%d",&j);
    for (i = 0; i < 7; i++)
    {
        howEnt[i] = (j-tmp) / money[i]; //求每个面值的个数
        tmp += howEnt[i]*money[i];
    }
 for(k = 0;k < 7; k++)
 {
  total+=howEnt[k];
 }
 printf("The min number of cards is %d/n",total);
 printf("see the numbers under the statement!/n");

    for (k = 0; k < 7; k++)
    {
        printf("The %d card is %d/n",money[k],howEnt[k]);
    }
}

 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值