9.设计评选优秀教师和优秀学生候选人的程序。如果学生的分数大于 90,则可评为优秀生;如果教师发表的论文数大于 3,则可评为优秀教师。
具体要求如下:
- 定义基类Base:
保护数据成员:
- char name[8]; //存放姓名
- int num; //存放分数或论文数
公有成员函数: - Base( ): 构造函数,输入姓名;
- void print( ):功能函数,输出数据成员;
- virtual int Isgood( )=0:纯虚函数,用于判断是否满足条件;
- 由基类派生学生类Student,定义公有成员函数:
- Student ( ): 构造函数,输入分数;
- int Isgood( ):根据优秀学生的标准,满足条件返回1,否则返回0;
- 由基类派生教师类Teacher,定义公有成员函数:
- Teacher ( ): 构造函数,输入论文数;
- int Isgood( ):根据优秀教师的标准,满足条件返回1,否则返回0;
- 在主函数中定义学生数组和教师数组, 输入一系列教师或学生的记录后,将优秀教师及学生候选
人的情况列出来,并体现运行的多态性
#include<iostream>
using namespace std;
class Base{
protected:
char name[8];
int num;
public:
Base(){
cout<<"name:";
cin>>name;
}
void print(){
cout<<"name:"<<name<<",num:"<<num<<endl;
}
virtual int Isgood()=0;
};
class Student:public Base{
public:
Student(){
cout<<"score:";
cin>>num;
}
virtual int Isgood(){
return num>90?1:0;
}
};
class Teacher:public Base{
public:
Teacher(){
cout<<"num:";
cin>>num;
}
virtual int Isgood(){
return num>3?1:0;
}
};
int main(){
cout<<"student:"<<endl;
Student stu[3];
cout<<"Teacher:"<<endl;
Teacher tea[3];
Base *p;
cout<<"good Student:"<<endl;
for(int i=0;i<3;i++){
p = &stu[i];
if(p->Isgood()){
p->print();
}
}
cout<<"good Teacher:"<<endl;
for(int i=0;i<3;i++){
p = &tea[i];
if(p->Isgood()){
p->print();
}
}
return 0;
}