读入?n(>0)名学生的姓名、学号、成绩,分别输出成绩最高和成绩最低学生的姓名和学号。
输入格式:
每个测试输入包含 1 个测试用例,格式为
第 1 行:正整数 n
第 2 行:第 1 个学生的姓名 学号 成绩
第 3 行:第 2 个学生的姓名 学号 成绩
... ... ...
第 n+1 行:第 n 个学生的姓名 学号 成绩
其中姓名 和学号 均为不超过 10 个字符的字符串,成绩为 0 到 100 之间的一个整数,这里保证在一组测试用例中没有两个学生的成绩是相同的。
输出格式:
对每个测试用例输出 2 行,第 1 行是成绩最高学生的姓名和学号,第 2 行是成绩最低学生的姓名和学号,字符串间有 1 空格。
输入样例:
3
Joe Math990112 89
Mike CS991301 100
Mary EE990830 95
输出样例:
Mike CS991301
Joe Math990112
思路:该题思想比较简单,?先输入需要输入的个数n,然后输入n个学生的姓名、学号、成绩。对他们的成绩进行比较大小得出最大数与最小数(亦可以用冒泡排序),然后输出最大成绩和最小成绩所属的学生相关信息。
#include<iostream>
#include<string>
using namespace std;
int main() {
int n, maxnumber, minnumber; //n为个数,maxnumber为成绩最高学生编号,minnumber同理
int maxcore = -1, mincore = 101;
cin >> n;
string *name = new string[n];
string *number = new string[n];
int *core = new int[n]; //n是输入的变量,所以core[n]要设置为动态数组。
for (int i = 0; i < n; i++) {
cin >> name[i] >> number[i] >> core[i];
}
for (int i = 0; i < n; i++) {
if (core[i] > maxcore) {
maxcore = core[i]; //比较大小得出最低成绩学生的编号
maxnumber = i;
}
for (int i = 0; i < n; i++) {
if (core[i] < mincore) {
mincore = core[i]; // //比较大小得出最高成绩学生的编号
minnumber = i;
}
}
}
cout << name[maxnumber] <<" "<< number[maxnumber] << endl;
cout << name[minnumber] <<" "<< number[minnumber];
}
?
|