|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
7-4 寻找最高分
分数 5
作者 李军
单位 陕西理工大学
  给定n(n⩾1)个学生的学号、姓名和3门课的考试成绩。编写程序找出总分最高的学生,并输出其学号、姓名和总分。如果有多个相同的最高分,则输出所有最高分学生的信息。
要求:
  存储学生信息及考试成绩的变量用如下结构类型来定义。
struct Student
{
char num[11]; //学号,最多10个字符
char name[11]; //姓名, 最多10个字符
int s1,s2,s3; //三门课的考试成绩
int total; //总成绩
} ;
typedef struct Student Student; //声明了一个结构类型Student类型
输入格式:
输入在一行中给出非负整数n(n⩾1)。随后n行,每行给出一个学生的信息,格式为学号 学号 姓名 成绩1 成绩2 成绩3,中间以空格分隔。
要求:
学号、姓名中不包括空白字符(空格、tab符)和空字符串。
输出格式:
在一行中输出总分最高学生的姓名、学号和总分,间隔一个空格。题目保证这样的学生是唯一的。
输入样例:
5
2109001 HuangJie 78 83 79
2109002 Liuhaipeng 79 80 77
2109003 Wangqiang 87 86 76
2109004 Liangfeng 92 89 79
2109005 Chengmeng 80 82 75
输出样例:
在这里给出相应的输出。例如:
2109004 Liangfeng 260
这题用C或者C++怎么做
- #include <iostream>
- #include <string>
- using namespace std;
- struct Student
- {
- char num[11]; //学号,最多10个字符
- char name[11]; //姓名, 最多10个字符
- int s1, s2, s3; //三门课的考试成绩
- int total; //总成绩
- };
- int main()
- {
- int n;
- cin >> n;
- Student stu[n];
- for (int i = 0; i < n; i++)
- {
- cin >> stu[ i].num >> stu[ i].name >> stu[ i].s1 >> stu[ i].s2 >> stu[ i].s3;
- stu[ i].total = stu[ i].s1 + stu[ i].s2 + stu[ i].s3;
- }
- int maxTotal = -1;
- for (int i = 0; i < n; i++)
- {
- if (stu[ i].total > maxTotal)
- {
- maxTotal = stu[ i].total;
- }
- }
- for (int i = 0; i < n; i++)
- {
- if (stu[ i].total == maxTotal)
- {
- cout << stu[ i].num << " " << stu[ i].name << " " << stu[ i].total << endl;
- }
- }
- return 0;
- }
复制代码
|
|