解题思路:建立结构体保存学号三科成绩以及总成绩
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; }
C语言程序设计教程(第三版)课后习题11.1 (C语言代码)浏览:676 |
2003年秋浙江省计算机等级考试二级C 编程题(2) (C语言代码)浏览:653 |
C语言程序设计教程(第三版)课后习题5.7 (C语言代码)浏览:587 |
简单的a+b (C语言代码)浏览:626 |
【计算直线的交点数】 (C语言代码)浏览:1442 |
C语言训练-自由落体问题 (C语言代码)浏览:610 |
C语言程序设计教程(第三版)课后习题9.8 (C语言代码)浏览:664 |
1017题解浏览:574 |
简单的a+b (C语言代码)浏览:572 |
2^k进制数 (C语言描述,蓝桥杯)浏览:1420 |