多吃点儿


私信TA

用户名:2021984130518

访问量:547

签 名:

等  级
排  名 269
经  验 5836
参赛次数 5
文章发表 13
年  龄 0
在职情况 学生
学  校
专  业

  自我简介:

TA的其他文章

解题思路:

注意事项:

参考代码:

#include <iostream>
#include <algorithm>//利用sort排序 
using namespace std;
struct Stu{
	int id;
	int chinese,math,english;
	int sum;
};
bool cmp(const Stu a,const Stu b){
	if(a.sum>b.sum){//如果a的总成绩大于b的总成绩,返回为true 
		return true;
	}
	if(a.sum==b.sum&&a.chinese>b.chinese){//总成绩相同,比较语文成绩 
		return true;
	}
	if(a.sum==b.sum&&a.chinese==b.chinese&&a.id<b.id){//总成绩相同,语文成绩相同,比较id学号 
		return true;
	}
	return false;
} 
int main(){
	int n;
	scanf("%d",&n);
	Stu stu[n+2];
	for(int i=0;i<n;i++){
		stu[i].id=i+1;
		scanf("%d%d%d",&stu[i].chinese,&stu[i].math,&stu[i].english);
		stu[i].sum=stu[i].chinese+stu[i].math+stu[i].english;
	}
	sort(stu,stu+n,cmp);
	for(int i=0;i<5;i++){
		if(i!=4){//控制一下换行 
			printf("%d %d\n",stu[i].id,stu[i].sum);
		}else{
			printf("%d %d",stu[i].id,stu[i].sum);
		}
	}
	return 0;
}


 

0.0分

0 人评分

  评论区

  • «
  • »