PTA:表彰优秀学生(c++,多态)

本博客介绍了一个使用C++实现的学生表彰系统,针对普通生、特招运动员和学科专长生设置不同标准。系统通过输入学生类型、学号、姓名及成绩,根据特定规则确定表彰名单。表彰条件涉及平均分排名、学科专长生的高分比例以及特招运动员的成绩与运动会表现。

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

学期结束,班主任决定表彰一批学生,已知该班学生数在6至50人之间,有三类学生:普通生,特招运动员,学科专长生,其中学科专长生不超过5人。
主函数根据输入的信息,相应建立GroupA, GroupB, GroupC类对象。
GroupA类是普通生,有2门课程的成绩(均为不超过100的非负整数);
GroupB类是特招运动员,有2门课程的成绩(均为不超过100的非负整数),1次运动会的表现分,表现分有:A、B、C、D共4等。
GroupC类是学科专长生,有5门课程的成绩(均为不超过100的非负整数)。
表彰人员至少符合以下3个条件中的一个:
(1)2门课程平均分在普通生和特招运动员中,名列第一者。
a.该平均分称为获奖线。
b.存在成绩并列时,则全部表彰,例如某次考试有2人并列第1,则他们全部表彰。
(2)5门课程平均分达到或超过获奖线90%的学科专长生,给予表彰。
(3)2门课程平均分达到或超过获奖线70%的特招运动员,如果其运动会表现分为A,给予表彰。
输入格式:每个测试用例占一行,第一项为类型,1为普通生,2为特招运动员,3为学科专长生, 输入0表示输入的结束。第二项是学号,第三项是姓名。对于普通生来说,共输入5项,第4、5项是课程成绩。对于特招运动员来说,共输入6项,第4、5项是课程成绩,第6项是运动会表现。对于学科专长生来说,共输入8项,第4、5、6、7、8项是课程成绩。
输出时,打印要表彰的学生的学号和姓名。(输出顺序与要表彰学生的输入前后次序一致)
函数接口定义:

以Student为基类,构建GroupA, GroupB和GroupC三个类

裁判测试程序样例:

#include<iostream>
#include <string>
using namespace std;

/* 请在这里填写答案 */

int main()
{
    const int Size=50;
    string num, name;
    int i,ty,s1,s2,s3,s4,s5;
    char gs;
    Student *pS[Size];
    int count=0;
    for(i=0;i<Size;i++){
        cin>>ty;
        if(ty==0) break;
        cin>>num>>name>>s1>>s2;
        switch(ty){
             case 1:pS[count++]=new GroupA(num, name, s1, s2); break;
             case 2:cin>>gs; pS[count++]=new GroupB(num, name, s1,s2, gs); break;
             case 3:cin>>s3>>s4>>s5; pS[count++]=new GroupC(num, name, s1,s2,s3,s4,s5); break;
        }			
    }
    for(i=0;i<count;i++) {
        pS[i]->display();
        delete pS[i];
    }
    return 0;
}

输入样例:

1 001 AAAA 96 80
2 009 BBB 82 75 A
1 007 CC 100 99
3 012 CCCC 97 95 90 99 93
1 003 DDD 62 50
1 022 ABCE 78 92
2 010 FFF 45 40 A
3 019 AAA 93 97 94 82 80
0

输出样例:

009 BBB
007 CC
012 CCCC
static double max1=-1;     //静态max1来在每次创建对象的时候记录当前的获奖线
class Student{
    protected:
    string No;
    string name;
    public:
    Student(string a,string s):No(a),name(s){};
    virtual void display()=0;    //纯虚函数
};
class GroupA:public Student{
    private:
    int score1;
    int score2;
    public:
    GroupA(string a,string s,int b,int c):Student(a,s),score1(b),score2(c){
        if((b+c)>max1*2.0){
            max1=(b+c)/2.0;      //构造函数的时候,如果条件满足更新获奖线
        }
    };
    void display();
};
void GroupA::display(){          //GroupA分数最高(包括同分)获奖
    if((score1+score2)==max1*2.0){     
        cout<<No<<" "<<name<<endl;
    }
}
class GroupB:public Student{
    private:
    int score1;
    int score2;
    char grade;
    public:
    GroupB(string a,string s,int b,int c,char d):Student(a,s),score1(b),score2(c),grade(d){
        if((b+c)>max1*2.0){
            max1=(b+c)/2.0;
        }
    };
    void display();
};
void GroupB::display(){       //GroupB分数达到获奖线70%并且A可以获奖同时分数最高也能获奖!
    if((score1+score2)>=max1*0.7*2.0&&grade=='A'||(score1+score2)==max1*2.0){
        cout<<No<<" "<<name<<endl;           //(一开始小看运动特长生了(┬_┬),运动特长生也有可能最高分!)
    }
}
class GroupC:public Student{
    private:
    int score1;
    int score2;
    int score3;
    int score4;
    int score5;
    public:
    GroupC(string a,string s,int b,int c ,int d ,int e ,int f):Student(a,s),score1(b),score2(c),score3(d),score4(e),score5(f){
 };
    void display();
};
void GroupC::display(){   //GroupC分数达获奖线90%也能获奖
    if((score1+score2+score3+score4+score5)>=max1*0.9*5.0){  
        cout<<No<<" "<<name<<endl;
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值