/*
*Copyright (c) 2013 ,烟台大学计算机学院
*All rights reserved.
*作者:张凤宁
*完成日期:2014年3月10
*版本号:v1.0
*问题描述:求值
*样例输入:
*样例输出:
*问题分析:用简单的方法,学会活学活用
*/
#include <iostream>
#include <string.h>
#include <iomanip>
using namespace std;
struct Student
{
char num[13];
int cpp;
int math;
int english;
int score;
int average;
};
void calculate(Student s[],int n); //计算总分和均分,数据在s数组中,共有n个元素
void sort1(Student [],int); //按总分降序排序
void sort2(Student [],int); //按学号升序排序
void output(Student [],int); //输出成绩单
void outputExcellent(Student [],int); //输出优秀者:总分超285,单科不低于90
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)
{
cout<<"总分"<<" "<<"均分"<<endl;
for(int i=0; i<11; i++)
{
s[i].score=s[i].cpp+s[i].math+s[i].english;
s[i].average=s[i].score/3;
cout<<s[i].score<<setw(8)<<s[i].average<<endl;
}
}
void output(Student s[],int)
{
cout<<"学号"<<setw(8)<<"姓名"<<setw(8)<<"C++"<<setw(8)<<"高数"<<setw(8)<<"英语"<<endl;
for(int i=0; i<11; i++)
{
cout<<s[i].num<<setw(8)<<s[i].name<<setw(8)<<s[i].cpp<<setw(8)<<s[i].math<<setw(8)<<s[i].english<<endl;
}
}
void sort1(Student s[],int stuNum)//按总分降序排序
{
Student a;
for(int i=0; i<stuNum-1; i++)//控制比较轮数
{
//控制每轮的比较次数
for(int j=0; j<stuNum-1-i; j++)
{
if(s[j].score<s[j+1].score)
{
a=s[j+1];
s[j+1]=s[j];
s[j]=a;
}
}
}
}
void sort2(Student s[],int stuNum)//按学号升序排序
{
Student c;
for(int i=0; i<stuNum-1; i++)//控制比较轮数
{
//控制每轮的比较次数
for(int j=0; j<stuNum-1-i; j++)
{
if(strcmp(s[j].num,s[j+1].num)>0)
{
c=s[j];
s[j]=s[j+1];
s[j+1]=c;
}
}
}
}
void outputExcellent(Student s[],int)//输出优秀者:总分超285,单科不低于90
{
for(int i=0; i<11; i++)
{
s[i].score=s[i].cpp+s[i].math+s[i].english;
if(s[i].score>285&&s[i].cpp>=90&&s[i].math>=90&&s[i].english>=90)
{
cout<<s[i].num<<setw(8)<<s[i].name<<setw(8)<<s[i].cpp<<setw(8)<<s[i].math<<setw(8)<<s[i].english<<setw(8)<<s[i].score<<endl;
}
}
}
运行结果:
心得体会:刚开始看到需要变很多代码时,感觉愁死了。但是在同学的帮助和自己的思考中最终还是完成一篇大作。很开心。