6-1 计算捐款总量

发布时间 2023-04-28 22:12:50作者: 刘冰宇

这里需要设计一个捐款人类Donator及一个相关函数getMaxName( ),Donator类中包含捐款人的姓名及其捐款额,其部分代码如下:

class Donator{
    private:
        string name; //捐款人姓名
        float money; //捐款金额,单位:元        
    public:
        void setName(string _name);
        void setMoney(float _money);
        string getName(){return name;}
        float getMoney(){return money;}
        
 

请根据题意将代码补充完整,以输出一批捐款人来到前后的捐款总金额,以及本批次捐款人中捐款最高者的姓名,题目保证捐款人数不少于1人。

裁判测试程序样例:

 
#include <iostream>
using namespace std;

class Donator{
    private:
        string name;
        float money; //单位:元        
    public:
        void setName(string _name);
        void setMoney(float _money);
        string getName(){return name;}
        float getMoney(){return money;}
        
/* 你编写的代码将被嵌入这里*/

//读取n个捐款人的姓名和捐款额 
void read(Donator dt[],int n){
    string name;
    float money;
    for(int i=0;i<n;i++){
        cin>>name>>money;
        dt[i].setName(name);
        dt[i].setMoney(money);
    }
}
 
int main(){
    int n;
    cin>>n; ////输入本批次将参与的捐款人数
    cin>>Donator::totalMoney; //输入目前已有的捐款总额 
    Donator::printTotal();
    Donator d[n];
    read(d,n);
    Donator::printTotal();
    cout<<getMaxName(d,n)<<endl;//输出本批次中捐款最高者姓名 
    return 0;     
} 
 

输入样例:

第一行为捐款人数及当前的捐款总额,第二行开始每行为一个捐款人的姓名和个人捐款金额。

3 28.5
Xiaoyu 12
Mike 81.5
Joey  50
 

输出样例:

输出本批次捐款人到达前后的捐款总额,及本批次中捐款最高者的姓名。

total:28.5
total:172
Mike
 1 static float totalMoney;
 2 static void printTotal()
 3 {
 4     cout<<"total"<<":"<<Donator::totalMoney<<endl;
 5 }
 6 };
 7 float Donator::totalMoney=0.0;
 8 void Donator::setName(string _name)
 9 {
10     
11     name=_name;
12 }
13 void Donator::setMoney(float _money){
14     
15     
16     totalMoney+=_money;
17     money= _money;
18 }
19 string getMaxName(Donator d[],int n)
20 {
21     float maxmoney=0;
22     int a=n;
23     string maxname;
24     for(int i=0;i<a;i++)
25     {
26         if (d[i].getMoney()>maxmoney)
27         {
28             maxmoney=d[i].getMoney();
29             maxname=d[i].getName();
30             
31             
32         }
33         
34     }
35     
36     return maxname;
37 }