题目:作为程序猿,最盼望的日子就是每月的9号了,因为这一天是发工资的日子,养家糊口就靠它了,呵呵
但是对于公司财务处的工作人员来说,这一天则是很忙碌的一天,财务处的小李最近就在考虑一个问题:如果每个员工的工资额都知道,最少需要准备多少张人民币,才能在给每位员工发工资的时候都不用员工找零呢?
这里假设程序猿的工资都是正整数,单位元,人民币一共有100元、50元、10元、5元、2元和1元六种。
输入:输入数据包含多个测试实例,每个测试实例的第一行是一个整数n(n<100),表示员工的人数,然后是n个员工的工资。
n=0表示输入的结束,不做处理。
输出:对于每个测试实例输出一个整数x,表示至少需要准备的人民币张数。每个输出占一行。
解答:
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
Scanner scanner = new Scanner(System.in);
while (scanner.hasNext()) {
int n = scanner.nextInt();//输入总人数
int sum=0;
int a[]=new int[n+1];
for(int i=0;i<=n;i++){
a[i]=scanner.nextInt();
if(a[i]==0){
break;
}
sum+=F(a[i]); //函数调用
}
System.out.println(sum);
}
scanner.close();
}
public static int[] money={100,50,20,10,5,2,1};//数组
public static int F(int n){
int size=0;
for(int i=0;i<money.length;i++){
if(n<money[i]){ //如果工资小于第i个纸币,继续往前循环
continue;
}
else{
size+=n/money[i]; //否则做除,求出一个纸币的面额
}
if(n%money[i]!=0){ //当工资不为整。
n=n%money[i]; //求余数,赋值给n,做循环使用。
}else{
break; //否则返回不同面额的张数。
}
}
return size;
}
}