2-2学生成绩统计(加强版)

来源:互联网 发布:互联网大数据面试题 编辑:程序博客网 时间:2024/05/23 20:25
/** 作    者: 霍雨佳* 完成日期:2014 年3月4日* 版 本 号:v1.0* 问题描述:利用结构体数组等知识对学生的成绩进行统计。* 样例输入:略* 样例输出:略* 问题分析:建立结构体,分析运用数组,建立自定义函数对学生的成绩进行统计。*/#include <iostream>#include <cstring>#include <iomanip>using namespace std;struct Student    {    char num[13];   //学号    char name[10];    int cpp;    int math;    int english;    int grade;    //总成绩    double average;//均值};void calculate(Student s[],int n);  //计算总分和均分,数据在s数组中,共有n个元素void sort1(Student s[],int n);      //按总分降序排序void sort2(Student s[],int);      //按学号升序排序void output(Student [],int);     //输出成绩单void outputExcellent(Student [],int);  //输出优秀者:总分超285,单科不低于90int i,j;int main(){    Student stu[]= {{"201152501104","Tom",65,69 ,68 },        {"201152501114","Jeery",94 ,89 ,63 },        {"201152501138","Speike",67 ,62 ,84 },        {"201152501204","Tyke",100 ,95 ,91 },        {"201152501202","Tuffy",59 ,80 ,55 },        {"201152501115","Butch",100 ,99 ,89 },        {"201152501201","Lightning",95 ,92 ,99 },        {"201152501145","Topsy",88 ,56 ,67 },        {"201152501203","Droopy",62 ,62 ,95 },        {"201152501140","Drupa",80 ,60 ,86 },        {"201152501205","Buzz",73 ,90 ,94}    };    int stuNum=sizeof(stu)/sizeof(stu[0]);  //用sizeof运算确定数组中元素个数    //计算总分和均分后输出    calculate(stu,stuNum);    cout<<"下面是成绩单:"<<endl;    output(stu,stuNum);    cout<<"优秀者名单:"<<endl;    outputExcellent(stu,stuNum);    //按总分降序排序后输出    sort1(stu,stuNum);    cout<<"按总分降序排序后:"<<endl;    output(stu,stuNum);    //按学号升序排序后输出    sort2(stu,stuNum);    cout<<"按学号升序排序后:"<<endl;    output(stu,stuNum);    return 0;}void calculate(Student s[],int n)//计算总分和均分,数据在s数组中,共有n个元素{    for(j=0; j<n; j++)    {        s[j].grade=s[j].cpp+s[j].math+s[j].english;        s[j].average=s[j].grade/3;    }    return;}void sort1(Student s[],int n)   //按总分降序排序{    Student m;    for(j=0; j<n-1; j++) //冒泡排序法    {        for(i=0; i<n-1-j; i++)        {            if(s[i].grade<s[i+1].grade)            {                m=s[i];                s[i]=s[i+1];                s[i+1]=m;            }        }    }}void sort2(Student s[],int n)      //按学号升序排序{    Student m;    for(j=0; j<n-1; j++) //冒泡排序法    {        for(i=0; i<n-1-j; i++)        {            if(s[i].num<s[i+1].num)            {                m=s[i];                s[i]=s[i+1];                s[i+1]=m;            }        }    }}void output(Student s[],int n)     //输出成绩单{    cout<<setw(13)<<"学号"<<setw(13)<<"姓名"<<setw(13)<<"总分"<<setw(13)<<"均分"<<endl;    for(j=0; j<n; j++)    {        cout<<setw(13)<<s[j].num<<setw(13)<<s[j].name<<setw(13)<<s[j].grade<<setw(13)<<s[j].average<<endl;    }}void outputExcellent(Student s[],int n)  //输出优秀者:总分超285,单科不低于90{    for(i=0; i<n; i++)    {        if(s[i].grade>285&&s[i].cpp>90&&s[i].math>90&&s[i].english>90)            cout<<setw(13)<<s[i].num<<setw(13)<<s[i].name<<setw(13)<<s[i].grade<<setw(13)<<s[i].average<<endl;    }}


运行结果:

 

      一开始老是报错还找不到原因,唉唉,搞了变天原来定义了函数不写就编译也不行 ⊙﹏⊙b汗

               排序的时候那个变量也要用student类型的啊,谨记谨记~~~

                        加油加油!!!

0 0
原创粉丝点击