六神大磊磊


私信TA

用户名:liu33

访问量:3621

签 名:

等  级
排  名 16909
经  验 789
参赛次数 1
文章发表 4
年  龄 18
在职情况 学生
学  校
专  业

  自我简介:

解题思路:结构体知识,及排序方法

注意事项:思路理清,哪一个比较重要

参考代码:

#include<stdio.h>

struct student

{

int num;//学号

int a,b,c;//三科成绩

int sum;//总分 

};

int main()

{

int n;

scanf("%d",&n);

struct student st[n+1],t;

int i,j;

for(i=1;i<=n;i++)

{

scanf("%d %d %d",&st[i].a,&st[i].b,&st[i].c); 

st[i].num=i;

st[i].sum=st[i].a+st[i].b+st[i].c;

}

//排序

for(i=1;i<=n-1;i++)

{

for(j=1;j<=n-i;j++)

{

if(st[j].sum<st[j+1].sum)

{

t=st[j];

st[j]=st[j+1];

st[j+1]=t;

}

if(st[j].sum==st[j+1].sum)

{

if(st[j].a<st[j+1].a)

{

t=st[j];

   st[j]=st[j+1];

   st[j+1]=t;

}

if(st[j].a==st[j+1].a)

{

if(st[j].num>st[j+1].num)

{

t=st[j];

       st[j]=st[j+1];

       st[j+1]=t;

}

}

}

}

}

for(i=1;i<=5;i++)

printf("%d %d\n",st[i].num,st[i].sum);

return 0;

}


 

0.0分

2 人评分

  评论区

  • «
  • »