Description:
有一些班级的学生需要按绩点计算并排名。每门课程的成绩只有在60分以上(含),才予以计算绩点。课程绩点的计算公式为: (课程成绩 – 50)÷10×学分数一个学生的总绩点为其所有课程绩点总和除以10。Input:
输入数据中含有一些班级(≤20)。每个班级的第一行数据n(≤10),a1,a2,a3,…,an,表示该班级共有n门课程,每门课程的学分分别为a1,a2,a3,…,an;班级数据中的第二行数据为一个整数m(≤50),表示本班级有m个学生;班级数据接下去有m行对应m个学生数据;每行学生数据中的第一个为字串s1(s1中间没有空格),表示学生姓名,后面跟有n个整数s1,s2,s3,…,sn,表示该学生各门课程的成绩(0≤si≤100)。Output:
以班级为单位输出各个学生按绩点分从大到小的排名。如果绩点分相同,则按学生名字的ASCII串值从小到大排名。每个班级的排名输出之前应先给出一行,描述班级序号“class #:”(#表示班级序号),班级之间应空出一行。排名时,每个学生占一行,列出名字和总绩点。学生输出宽度为10个字符,左对齐,在空出一格后列出总绩点。
Input Sample:
2
3 3 4 3
3
张三 89 62 71
Smith 98 50 80
王五 67 88 91
4 3 3 5 6
4
李四 90 80 90 85
张三 99 97 96 95
John 98 97 80 87
Mary 80 87 89 98
Output Sample:
Class 1:
王五 3.26
Smith 2.34
张三 2.28
Class 2:
张三 7.88
Mary 6.84
John 6.57
李四 6.20
代码如下:
#include<iostream>
#include<fstream>
#include<set>
#include<string>
#include<queue>
#include<set>
#include<iterator>
#include<algorithm>
#include<functional>
#include<iomanip>
#include<numeric>
using namespace std;
class student
{
public:
string name;
double dig;
bool operator < (const student& stu) const
{
if (stu.dig != dig)
{
return dig>stu.dig;
}
return name<stu.name;
}
};
int main()
{
#ifdef ONLINE_JUDGE
#else
freopen("D:\\in.txt", "r", stdin);
freopen("D:\\out.txt", "w", stdout);
#endif
int classnum(0);//班级总数
int coursenum(0);//课程总数
int stunum(0);//学生总数
string name;//学生的姓名
int score(0);//学生的课程成绩
vector<int> vxf;//学分向量
vector<student> coll;//学生向量
student stu;
cin >> classnum;
for (int k = 0; k < classnum;k++)
{
vxf.clear();
coll.clear();
coursenum = 0;
stunum = 0;
cin >> coursenum;
int n;//学分
for (int i = 0; i < coursenum; i++)
{
cin >> n;
vxf.push_back(n);
}
cin >> stunum;
for (int i = 0; i < stunum; i++)
{
double jidian = 0;
cin >> name;
for (int j = 0; j < coursenum; j++)
{
cin >> score;
if (score < 60)
{
continue;
}
jidian += (double)(score - 50) / 10 * vxf.at(j);
}
stu.name = name;
stu.dig = jidian/10;
coll.push_back(stu);
}
sort(coll.begin(),coll.end());
cout << (k ? "\n" : "");//处理每一个班,这个地方的思路要注意
cout << "Class " << k + 1 << ":" << endl;
for (vector<student>::iterator it = coll.begin(); it != coll.end(); it++)
{
//使用fixed,表明是定点输出
//或用cout.precesion(n),来设定小数点后保留n位
//输出时加“fixed”参数,表明是定点输出
cout << fixed << setprecision(2);
cout << left << setw(11);//此设置只能使用一次
cout << (*it).name << (*it).dig << endl;
}
}
return 0;
}