琨琨爸


私信TA

用户名:wangkunkun

访问量:353

签 名:

等  级
排  名 19783
经  验 671
参赛次数 0
文章发表 11
年  龄 0
在职情况 学生
学  校 南京市
专  业

  自我简介:

解题思路:
     网站指定是贪心算法,那就是最简单的类似背包题目。先从最大面值的钱开始尝试
注意事项:
  
参考代码:

#include<bits/stdc++.h>

using namespace std;

int money[6]={100,50,10,5,2,1};

int main()

{

int n; cin>>n;

while(n!=0){

int cnt=0;

for(int i=0;i<n;i++){

   int salary; cin>>salary;

   //对每个人的工资计算需要多少张钱

    for( int j=0;j<6;j++) {

        if(salary%money[j]==0)  //整除某张钱

            {

              cnt+= salary/money[j];

              break;

            }

        else if( salary/money[j]==0) //salary比这张钱小,需要转到下一张钱再计算

                   continue;

        else //if(salary/money[j]>0)

           {

                  cnt+=salary/money[j];

                  salary=salary%money[j];                                      

            }         

            /*int t = salary/money[j];

            salary -= t*money[j];

            cnt+=t;*/  //两种方法都可以。

    }

}

cout<<cnt<<endl;

cin>>n; //输入0表示 多行实例 输入结束

}

 

return 0;

}


 

0.0分

0 人评分

看不懂代码?想转换其他语言的代码? 或者想问其他问题? 试试问问AI编程助手,随时响应你的问题:

编程语言转换

万能编程问答  

代码解释器

代码纠错

SQL生成与解释

  评论区