题目: 编程实现查找优异生的功能——用户输入多个学生的成绩,输出总分最高的学生姓名和各科成绩
要求: 设计一个学生类(Student),包括
1)属性:姓名(name),数学成绩(mscore),语文成绩(cscore),英语成绩(escore);
2)方法:
- 构造方法,来构造每个具体的学生对象
- 计算总成绩方法getSum(self),返回三个成绩的和
- 获得优异生姓名,数学成绩,语文成绩,英语成绩的方法getBest(self),返回4个结果内容(优异生姓名,数学成绩,语文成绩,英语成绩)
输入格式:
通过4行输入:
第一行输入多个学生姓名,以空格分隔
第二行输入多个数学成绩,以空格分隔
第三行输入多个语文成绩,以空格分隔
第四行输入多个英语成绩,以空格分隔
注意:学生姓名个数要和成绩个数保持一致
输出格式:
在一行中,输出总分最高的学生及其各科科目成绩,以空格分隔。
输入样例:
在这里给出一组输入。例如:
Jack Tom Jim
95 84 32
90 75 45
85 90 67
输出样例:
在这里给出相应的输出。例如:
Jack 95 90 85
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
class student {
private:
string name;
double mscore;
double cscore;
double escore;
public:
student() {};
student(string _name, double _mscore, double _cscore, double _escore);
student getbest(student* s, int count);
void prin_best(student aa);
double getsum();
};
void student::prin_best(student aa) {
cout << aa.name << " " << aa.mscore << " " << aa.cscore << " " << aa.escore;
}
double student::getsum() {
return mscore + cscore + escore;
}
student::student(string _name, double _mscore, double _cscore, double _escore) {
this->name = _name;
this->mscore = _mscore;
this->cscore = _cscore;
this->escore = _escore;
}
student student::getbest(student* s, int count) {
double sum[100];
for (int i = 0; i < count; i++) {
sum[i] = s[i].getsum();
}
sort(sum + 0, sum + count);
for (int i = 0; i < count; i++) {
if (sum[count - 1] == s[i].getsum())
return s[i];
}
}
int main() {
student v[100];
string name[100];
double math[100], eng[100], ch[100];
int count = 0;
while (1) {
cin >> name[count++];
char b;
b = getchar();
if (b == '\n') break;
}
int w = count;
count = 0;
while (count < w) cin >> math[count++];
count = 0;
while (count < w) cin >> ch[count++];
count = 0;
while (count < w) cin >> eng[count++];
for (int i = 0; i < w; i++) {
v[i] = student(name[i], math[i], ch[i], eng[i]);
}
student ss;
student aa = ss.getbest(v, w);
aa.prin_best(aa);
return 0;
}