C语言实现校园十佳歌手案例

校园十大歌手

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运行结果

在这里插入图片描述

  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值