/*
*Copyright (c) 2014, 烟台大学计算机学院
* All right reserved.
* 文件名称:test.cpp
* 作者:陈丹
* 完成时间:2014年11月23号
* 版本号:v1.0
*
*问题描述:在数组score中将要存储某小组C++程序设计的成绩,请设计实现下面的各功能函数,并在main函数中调用,组合成一个完整的应用.
(1)输入小组人数及成绩,要保证成绩在0-100之间;
(2)输出该小组的最高成绩、最低成绩、平均成绩;
(3)输出考得最高成绩和最低成绩的同学的人数;
(4)输出考得最高成绩和最低成绩的同学的学号.
*输入描述:输入小组人数及成绩
*程序输出:同问题描述
*/
#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,double aver); //返回数组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;
double aver;
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);
aver=get_avg_score(score, num);
cout<<endl<<"标准偏差为:"<<get_stdev_score(score, num,aver);
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)
{
int sc;
for(int i=0; i<n; ++i) //输入num名同学的成绩
{
cout<<"请输入第"<<i<<"位同学的成绩:";
cin>>sc;
s[i]=sc;
while(sc>100||sc<0)
{
cout<<"错误!请重新输入请输入第"<<i<<"位同学的成绩:";
cin>>sc;
s[i]=sc;
}
}
return;
}
int get_max_score(int s[], int n)
{
int Max=0;
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=100;
for(int i=0; i<n; ++i)
{
if(Min>s[i])Min=s[i];
}
return Min;
}
double get_avg_score(int s[], int n)
{
double ave;
int sum=0;
for(int i=0; i<n; ++i)
{
sum+=s[i];
}
ave=sum/n;
return ave;
}
double get_stdev_score(int s[], int n,double aver)
{
double stdev;
double sum=0;
for(int i=0; i<n; ++i)
{
sum=sum+((s[i]-aver)*(s[i]-aver));
}
stdev=sqrt(sum/(n-1));
return stdev;
}
int count(int x, int s[], int n)
{
int M=0;
for(int i=0; i<n; ++i)
{
if(s[i]==x)++M;
}
return M;
}
void output_index(int x, int s[], int n)
{
for(int i=0; i<n; ++i)
{
if(s[i]==x)
{
cout<<i<<' ';
}
}
return;
}
运行结果: