解题思路:建立结构体保存学号三科成绩以及总成绩
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语言程序设计教程(第三版)课后习题7.2 (C语言代码)浏览:1175 |
C语言程序设计教程(第三版)课后习题12.1 (C语言代码)浏览:1026 |
C语言程序设计教程(第三版)课后习题5.4 (C语言代码)浏览:940 |
C语言程序设计教程(第三版)课后习题1.5 (C++代码)浏览:1114 |
【偶数求和】 (C语言代码)浏览:674 |
C语言程序设计教程(第三版)课后习题1.6 (C语言代码)浏览:732 |
C语言训练-数字母 (C语言代码)浏览:670 |
【排队买票】 (C语言代码)浏览:944 |
C语言训练-列出最简真分数序列* (C语言代码)浏览:658 |
【魔板】 (C++代码)(时间超限,希望会的帮我改正一下)浏览:804 |