QvQ


私信TA

用户名:927937414

访问量:30535

签 名:

还是好好学习吧

等  级
排  名 79
经  验 9649
参赛次数 9
文章发表 44
年  龄 19
在职情况 学生
学  校
专  业 软件工程

  自我简介:

还没学算法的弱鸡

解题思路:建立结构体保存学号三科成绩以及总成绩

struct note{
	int num;
	int YuWen,ShuXue,YingYu;
	int Allscore;
}stu[305];

调用sort按题目要求进行输出,详细见参考代码


注意事项:只输出前五名

参考代码:

#include <iostream>
#include <algorithm>
using namespace std;
struct note{
	int num;
	int YuWen,ShuXue,YingYu;
	int Allscore;
}stu[305];
int comp(note a,note b){
	if(a.Allscore!=b.Allscore)	//按总分大的排 
			return a.Allscore>b.Allscore;
	else{	//总分相等 
		if(a.YuWen!=b.YuWen)	//按语文成绩排 
			return a.YuWen>b.YuWen;
		else	//总分相等且语文成绩相等 
			return a.num<b.num;	//按学号小排 
	}
}
int main(){
	int n;
	cin>>n;
	for(int i=0;i<n;i++)	//初始化学号 
		stu[i].num=i+1;
	for(int i=0;i<n;i++){
		cin>>stu[i].YuWen>>stu[i].ShuXue>>stu[i].YingYu;	//输入三科成绩 
		stu[i].Allscore=stu[i].YuWen+stu[i].ShuXue+stu[i].YingYu;	//保存成绩和 
	}
	sort(stu,stu+n,comp);	//排序 
	for(int i=0;i<5;i++)	/*输出,千万记得是5,不是n-1*/ 
		cout<<stu[i].num<<" "<<stu[i].Allscore<<endl;
	return 0;
}

记得点赞哦!

 

0.0分

12 人评分

  评论区

写得差不多,想不通哪里错了:
#include<iostream>
#include <algorithm>
using namespace std;
int n;
struct stu{
	int score[3], rank, total;
}x[400];
inline bool cmp(const stu a, const stu b)
{
	if(a.total!=b.total) return a.total>b.total;
	else if(a.score[0]>b.score[0]) return a.score[0]>b.score[0];
	else return a.rank<b.rank;
}
int main()
{
	cin>>n;
	for(int i=1; i<=n; i++)
	for(int j=1; j<=3; j++)
	{
		cin>>x[i].score[j-1];
		x[i].rank = i;
		x[i].total += x[i].score[j-1];
	}
	sort(x+1, x+n+1, cmp);
	for(int i=1; i<=5; i++)
	cout<<x[i].rank<<" "<<x[i].total<<endl;
	return 0;
}
2019-07-20 21:01:42
  • «
  • 1
  • »