解题思路:
注意事项:注意题目要求,先比总成绩,在总成绩相同的情况下比较语文成绩,在语文成绩相同的情况下比较学号,学号小的排名在前。
参考代码:
#include <stdio.h>
#include <stdlib.h>
struct stu
{
int num;
int a, b, c;
int sum;
};
void sort(int n,struct stu arr[])
{
for(int i=0;i<n-1;i++)
{
for(int j=0;j<n-1-i;j++)
{
if(arr[j].sum<arr[j+1].sum)
{
struct stu temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
else if(arr[j].sum==arr[j+1].sum)
{
if(arr[j].a<arr[j+1].a)
{
struct stu temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
else if(arr[j].a==arr[j+1].a)
{
if(arr[j].num>arr[j+1].num)
{
struct stu temp=arr[j];
arr[j]=arr[j+1];
arr[j+1]=temp;
}
}
}
}
}
}
int main()
{
int n;
scanf("%d", &n);
struct stu st[n];
for(int i=0; i<n; i++)
{
scanf("%d %d %d", &st[i].a, &st[i].b, &st[i].c);
st[i].num = i+1;
st[i].sum = st[i].a + st[i].b + st[i].c;
}
sort(n,st);
for(int i=0; i<5; i++)
{
printf("%d %d\n",st[i].num,st[i].sum);
}
return 0;
}
0.0分
2 人评分
C语言程序设计教程(第三版)课后习题11.5 (C语言代码)浏览:615 |
最长单词 (C语言代码)浏览:1363 |
printf基础练习2 (C语言代码)浏览:305 |
P1001 (C语言代码)浏览:800 |
C语言程序设计教程(第三版)课后习题1.5 (C语言代码)浏览:530 |
WU-蓝桥杯算法提高VIP-勾股数 (C++代码)浏览:1592 |
WU-判定字符位置 (C++代码)浏览:1396 |
剪刀石头布 (C语言代码)浏览:748 |
IP判断 (C语言代码)浏览:762 |
【矩阵】 (C++代码)浏览:936 |