您的位置:首页 > 其它

第十三周 项目3:成绩处理函数版

2014-11-24 11:12 197 查看
/*
*Copyright (c)2014,烟台大学计算机与控制工程学院
*All rights reserved.
*文件名称:succeed.cpp
*作    者:刘天恩
*完成日期:2014年11月24日
*版 本 号:v1.0
*问题描述:输入,求最大值最小值等所有功能都通过自定义函数完成。
*程序输入:输入小组的人数以及各人的成绩。
*程序输出:输出最高成绩、最低成绩和平均成绩,考得最高成绩和最低成绩人数以及学号,标准偏差。
*/

#include <iostream>
#include<cmath>
using namespace std;
void input_score(int s[], int n);      //将小组中n名同学的成绩输入数组s
int get_max_score(int s[], int n);     //返回数组s中n名同学的最高成绩值
int get_min_score(int s[], int n);      //返回数组s中n名同学的最低成绩值
double get_avg_score(int s[], int n);     //返回数组s中n名同学的平均成绩值
double get_stdev_score(int s[], int n);    //返回数组s中n名同学成绩值的标准偏差
int count(int x, int s[], int n);       //返回在数组s中n名同学中有多少人得x分(实参给出最高/低时,可以求最高/低成绩的人数)
void output_index(int x, int s[], int n);    //在函数中输出数组s中n名同学中得x分的学号(下标)
int main(void)
{
int score[50]; //将score设为局部变量,通过数组名作函数参数,传递数组首地址,在函数中操作数组
int num;       //小组人数也设为局部变量,将作为函数的实际参数
int max_score,min_score;
cout<<"小组共有多少名同学:";
cin>>num;
cout<<endl<<"请输入学生成绩:"<<endl;
input_score(score, num);  //要求成绩在0-100之间
max_score=get_max_score(score, num);
cout<<endl<<"最高成绩为:"<<max_score<<",共有 "<<count(max_score, score, num )<<" 人。";
min_score=get_min_score(score, num);
cout<<endl<<"最低成绩为:"<<min_score<<",共有 "<<count(min_score,score, num )<<" 人。";
cout<<endl<<"平均成绩为:"<<get_avg_score(score, num);
cout<<endl<<"标准偏差为:"<<get_stdev_score(score, num);
cout<<endl<<"获最高成绩的学生(学号)有:";
output_index(max_score,score, num);
cout<<endl<<"获最低成绩的学生(学号)有:";
output_index(min_score,score, num);
cout<<endl;
return 0;
}

void input_score(int s[],int n)
{
for(int i=0;i<n;i++)
{
do
{
cout<<"请输入第"<<i<<"位同学的成绩:";
cin>>s[i];
}while(s[i]<0||s[i]>100);
}
return;
}
int get_max_score(int s[],int n)
{
int max=-1;      //认为第一个元素最小
for(int i=0;i<n;i++)
{
if(max<s[i])
max=s[i];
}
return max;
}
int get_min_score(int s[],int n)
{
int min=101;         //认为第一个元素最大
for(int i=0;i<n;i++)
{
if(min>s[i])
min=s[i];
}
return min;
}
double get_avg_score(int s[],int n)
{
int sum=0,m;
for(int i=0;i<n;i++)
sum+=s[i];
m=sum/n;
return m;
}
double get_stdev_score(int s[],int n)
{
double ave;
int f,F=0;
ave=get_avg_score(s,n);     //调用函数求的平均值
for(int i=0;i<n;i++)
{
f=(s[i]-ave)*(s[i]-ave);
F=F+f;
}
return sqrt(F/(n-1));
}
int count(int x,int s[],int n)
{
int time=0;     //把出现的最高分最低分次数初始化为0
for(int i=0;i<n;i++)
{
if(s[i]==x)
time++;
}
return time;
}
void output_index(int x,int s[],int n)
{
for(int i=0;i<n;i++)
{
if(s[i]==x)
cout<<i<<" ";
}
return;
}


运行结果:

内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: