问题 C: EXCEL排序

本文介绍如何使用C++实现一个学生信息结构,并通过三个不同的比较函数实现按学号升序、姓名字典序非递减和成绩非递减排序的功能。通过`<cstdio>`, `<cstring>`, `<algorithm>`等库函数,详细展示了排序操作在结构体数组中的应用。
摘要由CSDN通过智能技术生成

终于能用上这个头文件的库函数了

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
struct stu{
	int no;
	char name[10];
	int score;
};

bool cmp1(struct stu stu1, struct stu stu2);
bool cmp2(struct stu stu1, struct stu stu2);
bool cmp3(struct stu stu1, struct stu stu2);
int main(){
	int N, C;
	int flag = 1;
	struct stu list[100010];
	while(scanf("%d %d", &N, &C) != EOF){
		if(N == 0){
			break;
		}
		
		for(int i = 0; i < N; i++){
			scanf("%d %s %d", &list[i].no, list[i].name, &list[i].score);
		}
		switch(C){
			case 1:sort(list, list+N, cmp1);
				break;
			case 2:sort(list, list+N, cmp2);
				break;
			case 3:sort(list, list+N, cmp3);
				break;
			default: printf("啥也不是!!!");
		}
		printf("Case %d:\n", flag);
		for(int i = 0; i < N; i++){
			printf("%06d %s %d\n", list[i].no, list[i].name, list[i].score);
		}
		flag++;	
	}
	
	return 0;
} 
//按学号递增排序
bool cmp1(struct stu stu1, struct stu stu2){
	return stu1.no < stu2.no;
}
//按姓名的非递减字典序排序
bool cmp2(struct stu stu1, struct stu stu2){
	if(strcmp(stu1.name, stu2.name) == 0){
		return stu1.no < stu2.no;
	}
	return strcmp(stu1.name, stu2.name) < 0;
}
//按成绩的非递减排序。当若干学生具有相同姓名或者相同成绩时,则按他们的学号递增排序。
bool cmp3(struct stu stu1, struct stu stu2){
	if(stu1.score == stu2.score || strcmp(stu1.name, stu2.name) == 0){
		return stu1.no < stu2.no;
	}else{
		return stu1.score < stu2.score;
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值