#include <iostream>
using namespace std;
#define N 500
struct student {
char id[13];
char name[11];
char major[11];
double English;
double spec1;
double spec2;
double total;
} stu[N], t;
void sort(struct student *p, int n) {
int i, j;
for (i = 0; i < n; i++) {
for (j = i; j < n; j++) {
if (p[i].total < p[j].total) {
t = p[i];
p[i] = p[j];
p[j] = t;
}
}
}
}
int main() {
int i, n, m;
cin >> m >> n;
for (i = 0; i < m; i++) {
cin >> stu[i].id >> stu[i].name >> stu[i].major >> stu[i].English >> stu[i].spec1 >> stu[i].spec2;
}
for (i = 0; i < m; i++) {
stu[i].total = stu[i].English + stu[i].spec1 + stu[i].spec2;
}
sort(stu, m);
for (i = 0; i < n; i++) {
cout << stu[i].id << "-" << stu[i].name << "-" << stu[i].major << "-" << stu[i].English << "-" << stu[i].spec1 <<
"-" << stu[i].spec2 << "-" << stu[i].total << endl;
}
return 0;
}
部分学生管理系统(排序)
最新推荐文章于 2024-09-16 16:07:55 发布
该代码片段展示了如何使用C++编程语言实现对学生信息(姓名、专业、英语、两门专业课成绩)进行排序,依据总成绩从高到低,最后输出排序后的学生ID、姓名、专业等信息。
摘要由CSDN通过智能技术生成