使用1,5,10,50,100元人民币,组合给定的X元,输出需要的人民币张数

本文介绍了一个使用C++实现的人民币组合算法,旨在通过不同面额的人民币纸币(1元、5元、10元、50元、100元)来组合成特定金额的方法。该算法考虑了每种面额的纸币数量限制,通过循环和条件判断实现了最优的组合方案,并输出所需纸币的总张数。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

使用1,5,10,50,100元人民币,组合给定的X元,输出需要的人民币张数

//人民币组合给定x元
#include<iostream>
using namespace std;
int main()
{
 int rmb[5] = { 1,5,10,50,100 };//人民币面额
 int haveMoney[5] = { 0,0,0,0,0 };//每种人民币的张数
 for (int i = 0; i < 5; i++)
 {
  cin >> haveMoney[i];
 }
 int money ;
 int sumnum = 0;
 cout << "输入money:" << endl;
 cin >> money;
 for (int i = 4; i >= 0; i--)
 {
  while (money>=rmb[i]&&haveMoney[i]>=1)
  {
   int num = money / rmb[i];
   if (haveMoney[i] > num)
   {
    money = money - num * rmb[i];
    haveMoney[i] = haveMoney[i] - num;
    sumnum = sumnum + num;
   }
   else if(haveMoney[i]<num)
   {
    money = money - haveMoney[i] * rmb[i];
    haveMoney[i] = haveMoney[i] - haveMoney[i];
    sumnum = sumnum + num;
   }
  }
 }
 if (money > 1)
 {
  cout << -1 << endl;
 }
 else
 {
  cout << sumnum;
 }
 system("pause");
 return 0;
}

注意:1.多个相同类型数据,可以使用数组,而且后面也可以使用for或者while循环2.每次都可以分两种情况,分别计算剩余的钱和剩余的钱的张数

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值