校园十大歌手
1.案例描述
转眼又迎来一年一度的校园十大歌手比赛,选手们个个积极应战,奋力抢夺冠军的宝座,如今最终得分已经分晓,为了知晓冠军、亚军和季军的得主,案例要求通过编程将拼到最后的这十位歌手的得分从低到高进行排序
2.案例设计
实质:根据分数给选手分数给选手姓名排序
1.创建一个结构体,用于存放选手的姓名和分数
2.给选手初始化
3.定义一个该类型结构体数组,存放选手
4.创建一个函数,给传输的结构体数组排序,
5.输出排序结果
3.代码实现
#include<stdio.h>
struct singers{//定义结构体singers
int score; //分数
char name[10];//名字
};
void input(struct singers *xx,int n){//赋值方法
for(int i =0;i<n;i++)
scanf("%s%d",xx[i].name,&xx[i].score);
}
void sort(struct singers *xx,int n){//根据分数给选手排序(冒泡排序法)
//从小到大
struct singers t;
for(int i = 0;i<n;i++){
for(int j = 0;j<n-i-1;j++){
if(xx[j].score>xx[j+1].score){
t = xx[j];
xx[j] = xx[j+1];
xx[j+1] = t;
}
}
}
}
int main(){
int n ;
printf("需要存多少个选手?\n");
scanf("%d",&n);
getchar();
struct singers singer[10];//定义结构体数组
printf("请输入%d个选手的姓名和分数:\n",n);
input(singer,n);//给选手赋值
printf("排序前:\n");
for(int a=0;a<n;a++){
printf("%s,%d",singer[a].name,singer[a].score);
printf("\n") ;
}
sort (singer,n);//根据选手的分数给选手排序
printf("排序后:\n");
for(int a=0;a<n;a++){
printf("%s,%d",singer[a].name,singer[a].score);
printf("\n") ;
}
printf("冠军:%s,亚军:%s,季军:%s",singer[n-1].name,singer[n-2].name,singer[n-3].name);
return 0 ;
}
4运行结果