【题解】发工资
【题目描述】
作为程序猿,最盼望的日子就是每月的9号了,因为这一天是发工资的日子,养家糊口就靠它了,呵呵
但是对于公司财务处的工作人员来说,这一天则是很忙碌的一天,财务处的小李最近就在考虑一个问题:如果每个员工的工资额都知道,最少需要准备多少张人民币,才能在给每位员工发工资的时候都不用员工找零呢?
这里假设程序猿的工资都是正整数,单位元,人民币一共有100元、50元、10元、5元、2元和1元六种。
【输入描述】
输入数据包含多个测试实例,每个测试实例的第一行是一个整数n(n<100),表示员工的人数,然后是n个员工的工资。
n=0表示输入的结束,不做处理。
【输出描述】
对于每个测试实例输出一个整数x,表示至少需要准备的人民币张数。每个输出占一行。
【样例输入】
3 1 2 3 0
【样例输出】
4
【题目分析】
找零钱类问题。贪心算法可以解决
【参考代码】
#include<bits/stdc++.h> using namespace std; int money[6]= {100,50,10,5,2,1}; //面额大小 int sum(int x) { int index=0,res=0; //表示下标和张数 while(x>0) { res+=x/money[index];//当前面额的最多张数 x=x- x/money[index] * money[index];//减去已计算的面额总值,并将面额减小 index++; } return res; } int main() { int n; int m,total=0; cin>>n; for(int i=0; i<n; i++) { cin>>m; total+=sum(m); } cout<<total<<endl; return 0; }
(adsbygoogle = window.adsbygoogle || []).push({});