C++sort函数使用(成绩排名)

需求:使用sort实现先按照成绩降序排名,如果名次相同则按照姓名按照字典序从小到大,实现排名。
分析:第一种方式给出将名次作为结构体的一个属性,第二种方式则直接输出

#include<stdio.h>
#include<algorithm>
#include<string.h>
using namespace std;
struct Student{
	char name[10];
	int score;
	int mingci;
}stus[5];
bool cmp(Student a,Student b){
	if(a.score!=b.score) 
		return a.score>b.score;
	else
		return strcmp(a.name,b.name)<0;
}
int main(){
	stus[0].score = 86;
	strcpy(stus[0].name,"li");
	stus[1].score = 83;
	strcpy(stus[1].name,"wei");
	stus[2].score = 83;
	strcpy(stus[2].name,"zhao");
	stus[3].score = 99;
	strcpy(stus[3].name,"zhang");
	sort(stus,stus+4,cmp);
	//记录排名 
	stus[0].mingci = 1 ;
	for(int i=1;i<4;i++){
		if(stus[i].score == stus[i-1].score)
			stus[i].mingci = stus[i-1].mingci;
		else
			stus[i].mingci = i+1;
	} 
	for(int i=0;i<4;i++){
		printf("\n%s %d %d\n",stus[i].name,stus[i].score,stus[i].mingci );	
	}
	return 0;
}

运行结果为
在这里插入图片描述

第二种方法,即采用直接输出的方式。

#include<stdio.h>
#include<algorithm>
#include<string.h>
using namespace std;
struct Student{
	char name[10];
	int score;
}stus[5];
bool cmp(Student a,Student b){
	if(a.score!=b.score) 
		return a.score>b.score;
	else
		return strcmp(a.name,b.name)<0;
}
int main(){
	stus[0].score = 86;
	strcpy(stus[0].name,"li");
	stus[1].score = 83;
	strcpy(stus[1].name,"wei");
	stus[2].score = 83;
	strcpy(stus[2].name,"zhao");
	stus[3].score = 99;
	strcpy(stus[3].name,"zhang");
	sort(stus,stus+4,cmp);
	int r = 1; 
	for(int i=0;i<4;i++){
		if(i > 0 && (stus[i].score!=stus[i-1].score))
		{
				r = i + 1;
				printf("\n%s%d排名%d \n",stus[i].name,stus[i].score,r);
			}
		else	{
				printf("\n%s%d排名%d \n",stus[i].name,stus[i].score,r);}

	}
	return 0;
}

运行结果如下
在这里插入图片描述

  • 0
    点赞
  • 5
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
成绩排名是根据一定的规则将学生按照成绩从高到低排列的过程。在给出的引用中,有三种不同的方法来实现成绩排名。 第一种方法是使用sort函数来实现,先按照成绩降序排名,如果成绩相同,则按照姓名的字典序从小到大进行排名。这种方法使用了结构体来存储学生的姓名和成绩,并定义了一个比较函数cmp来确定排序的规则。然后使用sort函数学生数组进行排序,最后输出每个学生的姓名、成绩和排名。 第二种方法也是使用sort函数来实现,同样是先按照成绩降序排名,如果成绩相同,则按照姓名的字典序从小到大进行排名。不同的是,这种方法使用了一个字符串数组来存储学生的姓名,而不是结构体数组。同样定义了一个比较函数cmp来确定排序的规则。然后使用sort函数对字符串数组进行排序,最后输出每个学生的姓名。 第三种方法也是直接输出的方式,同样是先按照成绩降序排名,如果成绩相同,则按照姓名的字典序从小到大进行排名。这种方法使用了结构体来存储学生的姓名和成绩,并定义了一个比较函数cmp来确定排序的规则。然后使用sort函数学生数组进行排序,最后通过一个循环遍历学生数组,并输出每个学生的姓名、成绩和排名。 以上是三种不同的方法来实现成绩排名,它们都可以根据给定的规则对学生成绩进行排序,并输出每个学生的排名。具体选择哪种方法可以根据实际情况和需求来决定。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *3* [C++sort函数使用成绩排名)](https://blog.csdn.net/q54188p/article/details/113398329)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] - *2* [蓝桥杯-算法提高-成绩排名-结构体+sort()排序](https://blog.csdn.net/weixin_44167903/article/details/107632484)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_2"}}] [.reference_item style="max-width: 50%"] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值