解题思路:
注意事项:
参考代码:
#include <stdio.h>
#include <stdlib.h>
typedef struct students{
char name[101];
int age;
int core;}st;
void input (st *l)
{
scanf("%s %d %d",l->name,&l->age,&l->core);
}
void print(st *l){
printf("%s %d %d\n",l->name,l->age,l->core);
}
//冒泡排序
void bubble(st *list,int n){
int i;
st t;
for(i=0;i<n-1;i++)
{
if(list[i].core>list[i+1].core)
{
t=list[i];
list[i]=list[i+1];
list[i+1]=t;
}
if(list[i].core==list[i+1].core)
{
if(strcmp(list[i].name,list[i+1].name)>0)
{
t=list[i];
list[i]=list[i+1];
list[i+1]=t;
}
}
if(strcmp(list[i].name,list[i+1].name)==0)
{
if(list[i].age>list[i+1].age)
{
t=list[i];
list[i]=list[i+1];
list[i+1]=t;
}
}
}
}
void bubblesort(st *list,int n){
int i;
for (i=n;i>1;i--)
bubble(list,i);
}
void main()
{
int N;
while(scanf("%d",&N)!=EOF)
{
if(N<=1000&&N>0)
{st list[N];
int i;
for(i=0;i<N;i++)
{
input(&list[i]);
if(getchar()=='\n')
continue;
}
bubblesort(list,N);
for(i=0;i<N;i++)
print(&list[i]);
}
}
return 0;
}
0.0分
0 人评分
C语言程序设计教程(第三版)课后习题7.3 (C语言代码)浏览:563 |
小九九 (C语言代码)浏览:530 |
C二级辅导-进制转换 (C语言代码)浏览:828 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:324 |
C语言训练-自守数问题 (C语言代码) long long浏览:1066 |
C语言训练-舍罕王的失算 (C++代码)(都给答案了还算什么)浏览:972 |
C语言程序设计教程(第三版)课后习题7.3 (C语言代码)浏览:1118 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:1884 |
C语言程序设计教程(第三版)课后习题8.7 (C语言代码)浏览:916 |
循环入门练习6 (C语言代码)浏览:968 |