C++实现按绩点排名

题目内容:有一些班级的学生需要按绩点计算并排名。每门课的成绩只有在60分以上(含),才予以计算绩点。课程绩点的计算公式为:(课程成绩-50÷10×学分数。一个学生的总绩点为其所有课程绩点总和除以10.

输入描述:输入数据中含有一些班级(数量≤20)。第一行为班级数量。每个班级的第一行数据为n≤10),表示该班级共有n门课程。每个班级的第二行数据为a1,a2,a3,……,an,表示每门课程的学分。班级数据中的第三行数据为一个整数m≤50),表示本班级有m个学生;班级数据接下去有m行对应m个学生数据;每行学生数据中的第一个为字串s1(s1中间没有空格),表示学生姓名,后面跟有n个整数s1,s2,s3,……sn,表示该学生各门课程的成绩(0≤si ≤100).

输出描述:以班级为单位输出各个学生按绩点分从大到小的排名。如果绩点分相同,则按学生名字的ASCII串值从小到大排名。每个班级的排名输出之前应先给出一行,描述班级序号“class #:”(#表示班级序号),班级之间应空出一行。排名时,每个学生占一行,列出名字和总绩点。学生输出宽度为10个字符,左对齐,在空出一格后列出总绩点。

题目分析:

(1)定义一个正整数作为班级数;定义一个正整数作为课程数量;定义一个double变量作为学分;定义一个double型向量容器存储学分;定义一个正整数作为班级人数;定义一个结构体存储学生的名称和总绩点;定义一个字符串变量作为学生名称;定义一个元素为结构体的向量容器存储最终学生名称和总绩点

(2)从键盘读入班级数

(3)对每个班级,从键盘读入课程数量,再读入每门课程的学分,并将每个学分插入到向量容器中

(4)对每个班级中的每个学生,从键盘读入学生名称,存储在结构体中

(5)对每个班级中的每个学生的每门课程,读入成绩,若成绩小于60,则继续读入下一门课程的成绩,否则计算该课程的绩点

(6)对每个班级中的每个学生,计算其总绩点,存储在结构体中,并插入向量容器

(7)编写比较函数,若总绩点不相等则按总绩点从大到小的顺序返回,若总绩点相等则按学生名字从小到大的顺序返回

(8)将向量容器中的元素按比较函数排序

(9)对向量容器中的每个元素,格式化输出其信息

参考代码:

#include <fstream>
#include <iostream>
#include <string>
#include <vector>
#include <algorithm>
#include <iomanip>

using namespace std;

struct student
{
    string s;
    double d;
};

bool myComp(const student &s1,const student &s2)
{
    if(s1.d!=s2.d) return s1.d>s2.d;
    if(s1.s!=s2.s) return s1.s<s2.s;
}

int main(int argc,char * argv[])
{
    int n;
    int c;
    double xf;
    vector<double> vxf;
    int p;
    string name;
    double score;
    student xs;
    vector<student> vxs;
    cin>>n;
    for(int i=0;i<n;i++)
    {
        cin>>c;
        for(int j=0;j<c;j++)
        {
            cin>>xf;
            vxf.push_back(xf);
        }
        cin>>p;
        for(int k=0;k<p;k++)
        {
            cin>>name;
            xs.s=name;
            xf=0.0;
            for(int m=0;m<c;m++)
            {
                cin>>score;
                if(score<60) continue;
                xf=xf+(score-50)/10*vxf[m];
            }
            xs.d=xf/10;
            vxs.push_back(xs);
        }
        cout<<(i?"\n":"");
        cout<<"Class "<<i+1<<":"<<endl;
        sort(vxs.begin(),vxs.end(),myComp);
        for(vector<student>::iterator it=vxs.begin();it<vxs.end();it++)
        {
            cout<<fixed<<setprecision(2);
            cout<<left<<setw(11);
            cout<<(*it).s<<(*it).d<<endl;
        }
        vxf.clear();
        vxs.clear();
    }
    system("pause");
    return 0;
}

运行结果:

posted @ 2013-10-21 21:13  源子陌  Views(2144)  Comments(0Edit  收藏  举报