C++:泛型编程vector(成绩排序)

时间:2022-03-19 15:00:43

泛型编程vector(成绩排序)

Time Limit(Common/Java):1000MS/3000MS Memory Limit:65536KByte
Total Submit:44 Accepted:22

Description

定义学生结构体,包括学号、及三门功课的成绩和总分,按照总分从小到大输出学生学号、总分和各门功课的成绩。如果总分相同,就按第1门课的分数小到大输出;如果第1门课的分数相同,就按第2门课的分数小到大输出;

Input

输入包含n(n<20)个学生的信息, 第1行学生人数。

第2行–第n+1行为学生信息,包括学号、及三门功课的成绩。

Output

从小到大输出学生学号与总分。

Sample Input

4
1001 70 80 90
1002 60 70 80
1003 80 90 70
1004 70 85 85

Sample Output

1002 210 60 70 80
1001 240 70 80 90
1004 240 70 85 85
1003 240 80 90 70


代码块:

#include <iostream>
#include <iomanip>
#include <vector>
#include<algorithm>
using namespace std;

typedef struct book1
{
int s1,s2,s3;
int p,s4;
}book;

bool compare(const book &a,const book &b)
{
if (a.s4<b.s4) return 1;
else if (a.s4==b.s4)
{
if (a.s1<b.s1) return 1;
else if (a.s1==b.s1)
{
if (a.s2<b.s2) return 1;
else if (a.s2==b.s2)
{
if (a.s3<b.s3) return 1;
else return 0;
}
else return 0;
}
else return 0;
}
else return 0;
}

int main()
{
int n,i,t;
cin>>t;n=t;
vector <book> v;
while (t--)
{
book bb;
cin>>bb.p>>bb.s1>>bb.s2>>bb.s3;
bb.s4= bb.s1+bb.s2+bb.s3;
v.push_back(bb);
}
sort(v.begin(),v.end(),compare);
for (i=0; i<n; i++)
cout<<v[i].p<<" "<<v[i].s4<<" "<<v[i].s1<<" "<<v[i].s2<<" "<<v[i].s3<<endl;


v.clear();

return 0;
system("pause");
}