成绩处理函数版
来源:互联网 发布:航天信息发票认证软件 编辑:程序博客网 时间:2024/04/28 12:22
/*Copyright (c) 烟台大学计算机与控制工程学院Author:刘慧艳Created:Edition:V1.0Describe: 用函数实现 在数组score中将要存储某小组C++程序设计的成绩,请设计实现下面的各功能函数,并在main函数中调用, 组合成一个完整的应用: (1)输入小组人数及成绩,要保证成绩在0-100之间; (2)输出该小组的最高成绩、最低成绩、平均成绩; (3)输出考得最高成绩和最低成绩的同学的人数; (4)输出考得最高成绩和最低成绩的同学的学号(设数组下标即学号,可能有相同的成绩)。 (5)(选做)求出所有同学成绩的标准偏差,标准偏差公式: 其中为样本(即某同学成绩),为均值(前面已经求出),为样本数目;*/#include <iostream>#include <cmath>using namespace std;void input_score(int s[], int n); //将小组中n名同学的成绩输入数组sint 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){ int i; for(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,i; for(i=0;i<n;++i) { if(s[i]>max) max=s[i]; } return max;}int get_min_score(int s[],int n){ int i,min=101; for(i=0;i<n;++i) { if(s[i]<min) min=s[i]; } return min;}double get_avg_score(int s[],int n){ int i,sum=0; double average; for(i=0;i<n;++i) { sum+=s[i]; } average=sum/n; return average;}double get_stdev_score(int s[],int n){ int c,i,sum=0; double stdev,avg; avg=get_avg_score(s,n); for(i=0;i<n;++i) { c=s[i]-avg; sum+=c*c; } return sqrt(sum/(n-1));}int count(int x,int s[],int n){ int Icount=0,i; for(i=0;i<n;++i) { if(s[i]==x) Icount++; } return Icount;}void output_index(int x,int s[],int n){ int i; for(i=0;i<n;++i) { if(s[i]==x) cout<<i<<" "; }cout<<endl;}
0 0
- 成绩处理函数版
- 成绩处理函数版
- 成绩处理函数版
- 成绩处理函数版
- 成绩处理函数版
- 成绩处理函数版
- 成绩处理函数版
- 成绩处理函数版
- 练习,成绩处理函数版
- 14-3成绩处理函数版
- 学生成绩处理(函数版)
- 项目3成绩处理函数版
- 第十三周项目成绩处理函数版
- 项目三-成绩处理函数版
- 提高项目13-成绩处理 函数版
- 第十四周-成绩处理函数版
- 14--3成绩处理函数
- 第十四周——成绩处理函数版
- OC-字符串常用操作(NSString、NSMutableString)
- 用C++设计一个不能被继承的类
- 【转】struts.xml详解
- 1-pydev插件的安装
- hdu 4930 Fighting the Landlords 出一手能打完或者打出来后对手没得接 就赢
- 成绩处理函数版
- repo文件详解
- 矩阵经典题目七:Warcraft III 守望者的烦恼(矩阵加速递推)
- Algorithm_判断一个数组是另外一个数组的子集
- putty.exe命令行参数及用法
- NSArrayNSNumber
- POJ 4927 Series 1 多校第六场 杨辉三角的应用
- PackageParser和AndroidManifest.xml注记
- hdu 1575 Tr A