本文主要是介绍C语言实现校园十佳歌手案例,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
校园十大歌手
1.案例描述
转眼又迎来一年一度的校园十大歌手比赛,选手们个个积极应战,奋力抢夺冠军的宝座,如今最终得分已经分晓,为了知晓冠军、亚军和季军的得主,案例要求通过编程将拼到最后的这十位歌手的得分从低到高进行排序
2.案例设计
实质:根据分数给选手分数给选手姓名排序
1.创建一个结构体,用于存放选手的姓名和分数
2.给选手初始化
3.定义一个该类型结构体数组,存放选手
4.创建一个函数,给传输的结构体数组排序,
5.输出排序结果
3.代码实现
#include<stdio.h>struct singers{//定义结构体singersint 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运行结果
这篇关于C语言实现校园十佳歌手案例的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!