/*
* Copyright (c) 2013, 烟台大学计算机学院
* All rights reserved.
* 作 者:王颖
* 完成日期:2013 年 12 月 04 日
* 版 本 号: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 j=0; j<n; j++)
do
{
cout<<"输入第"<<j<<"位同学的成绩: ";
cin>>s[j];
}
while(s[j]<0||s[j]>100);
}
int get_max_score(int s[], int n) //数组s中n名同学的最高成绩值
{
int max=-1;
for(int i=0; i<n; i++)
{
if(s[i]>max)
max=s[i];
}
return max;
}
int get_min_score(int s[], int n) //数组s中n名同学的最低成绩值
{
int min=100,i;
for(i=0; i<n; i++)
{
if(s[i]<min)
{
min=s[i];
}
}
return min;
}
double get_avg_score(int s[],int n) //数组s中n名同学的平均成绩值
{
int sum=0,ave=0;
for(int j=0; j<n; j++)
{
sum+=s[j];
}
if(n!=0)
{
ave=sum/n;
}
return ave;
}
double get_stdev_score(int s[], int n) //数组s中n名同学成绩值的标准偏差
{
int m=0;
double t,sum=0;
for(int i=0; i<n; i++)
{
m=s[i]-get_avg_score(s,n);
sum=sum+m*m;
}
t=sqrt(sum/(n-1));
return t;
}
int count(int x, int s[], int n) //在数组s中n名同学中有多少人得x分
{
int y=0;//(实参给出最高/低时,可以求最高/低成绩的人数)
for(int k=0; k<n; k++)
{
if(x==s[k])
{
y++;
}
}
return y;
}
void output_index(int x, int s[], int n) //在函数中输出数组s中n名同学中得x分的学号(下标)
{
for(int i=0; i<n; i++)
{
if(s[i]==x)
cout<<i<<" ";
}
cout<<endl;
}
心得体会:因为一个细节,我做了这么多天,不容易啊······