解题思路:
注意事项:1.成绩小的在前 2.名字小的在前(比较的整个字符串不是首字母) 3.年龄小的在前
参考代码:#include<stdio.h>
typedef struct
{ char a[1000];
int b;//年龄
int c;//成绩
}Student;
void f(Student d[2000],int n)
{ Student k;
for(int i=n-2;i>=0;i--)
for(int j=0;j<=i;j++)
{ if(d[j].c>d[j+1].c)
{ k=d[j];
d[j]=d[j+1];
d[j+1]=k;
}
else if(d[j].c==d[j+1].c)
{ if(strcmp(d[j].a,d[j+1].a)>0)
{ k=d[j];
d[j]=d[j+1];
d[j+1]=k;
}
else if(strcmp(d[j].a,d[j+1].a)==0&&d[j].b>d[j+1].b)
{ k=d[j];
d[j]=d[j+1];
d[j+1]=k;
}
}
}
for(int i=0;i<n;i++)
printf("%s %d %d\n",d[i].a,d[i].b,d[i].c);
}
int main()
{ int n;
Student d[2000];
while(scanf("%d",&n)==1)
{ for(int i=0;i<n;i++)
scanf("%s %d %d",d[i].a,&d[i].b,&d[i].c);
f(d,n);
}
return 0;
}
0.0分
0 人评分