解题思路:
注意事项:
参考代码:
#include<stdio.h>
struct garde {
int sum;
int xuehao;
};
int main(){
int arr[1000] = { 0 };
int brr[1000] = { 0 };
int crr[1000] = { 0 };
int n;
int temp1;
struct garde su[1000];
scanf("%d", &n);
for (int i = 1; i <= n; i++) {
scanf("%d", &arr[i]);
scanf("%d", &brr[i]);
scanf("%d", &crr[i]);
}
for (int i = 1; i <= n; i++) {
su[i].sum = arr[i] + brr[i] + crr[i];
su[i].xuehao = i;
}
for (int i = 1; i <= n; i++) {
for (int k = 1; k <= n - 1; k++) {
if (su[k].sum < su[k + 1].sum) {
temp1 = su[k].sum;
su[k].sum = su[k + 1].sum;
su[k + 1].sum = temp1;
temp1 = su[k].xuehao;
su[k].xuehao = su[k + 1].xuehao;
su[k + 1].xuehao = temp1;
temp1 = arr[k];
arr[k] = arr[k + 1];
arr[k+1] = temp1;
}
}
}
for (int k = 1; k <= n - 1; k++) {
if (su[k].sum == su[k + 1].sum&&arr[k]<arr[k+1]) { //对总分相同的两个学生根据语文成绩排序
temp1 = su[k].sum;
su[k].sum = su[k + 1].sum;
su[k + 1].sum = temp1;
temp1 = su[k].xuehao;
su[k].xuehao = su[k + 1].xuehao;
su[k + 1].xuehao = temp1;
temp1 = arr[k];
arr[k] = arr[k + 1];
arr[k + 1] = temp1;
}
}
if (n >= 5) { //判断学生总数是否大于5(所给的样例可能都是大于五的,这步可能不需要)
for (int i = 1; i <= 5; i++) {
printf("%d ", su[i].xuehao); //根据格式进行输出
printf("%d\n", su[i].sum);
}
}
else if (n < 5) {
for (int i = 1; i <= n; i++) {
printf("%d ", su[i].xuehao);
printf("%d\n", su[i].sum);
}
}
return 0;
}
0.0分
0 人评分
C语言程序设计教程(第三版)课后习题7.5 (C语言代码)浏览:608 |
C语言考试练习题_排列 (C++代码)浏览:638 |
最长单词 (C语言代码)浏览:1376 |
C二级辅导-阶乘数列 (C语言代码)浏览:691 |
C语言程序设计教程(第三版)课后习题9.6 (C语言代码)浏览:373 |
水仙花 (C语言代码)浏览:1052 |
简单的a+b (C语言代码)浏览:580 |
演讲大赛评分 (C语言代码)浏览:1634 |
C语言程序设计教程(第三版)课后习题6.8 (C语言代码)浏览:617 |
C语言程序设计教程(第三版)课后习题9.8 (C语言代码)浏览:529 |