第十三周项目3 函数版成绩处理(返回)
来源:互联网 发布:图片服务器 java 框架 编辑:程序博客网 时间:2024/05/18 15:24
/* *Copyright (c)2014,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:main.cpp *作 者:苏强 *完成日期:2014年11月24日 *版 本 号:v1.0 * *问题描述:用函数处理保存成绩的数组。 *程序输出:输出最高成绩、最低成绩和平均成绩,考得最高成绩和最低成绩人数以及学号,标准偏差。 */ #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; 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) //将小组中n名同学的成绩输入数组s{ int i=0; while(i<n) { cout<<"输入第"<<i<<"位同学的成绩:"; cin>>s[i]; if(s[i]>100||s[i]<0) continue; i++; } return ;}int get_max_score(int s[], int n)//返回数组s中n名同学的最高成绩值{ int i,max=0; for(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 i,min=100; 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 i,sum=0,ave; for(i=0; i<n; ++i) sum=sum+s[i]; ave=sum/n; return ave;}double get_stdev_score(int s[], int n) //返回数组s中n名同学成绩值的标准偏差{ int i,sum=0,a; double S=0,a,ave,t=0; for(i=0; i<n; ++i) sum=sum+s[i]; ave=sum/n; for(i=0; i<n; ++i) { a=s[i]-ave; t=t+a*a; } S=sqrt(t/(n-1)); return S;}int count(int x, int s[], int n) //返回在数组s中n名同学中有多少人得x分(实参给出最高/低时,可以求最高/低成绩的人数){ int i,a=0; for(i=0; i<n; ++i) if(s[i]==x) a++; return a;}void output_index(int x, int s[], int n){ int i; for(i=0; i<n; ++i) if(s[i]==x) cout<<i<<" ";}
0 0
- 第十三周项目3 函数版成绩处理(返回)
- 第十三周项目成绩处理函数版
- 第十三周项目3-成绩处理函数版
- 第十三周项目 3 成绩处理函数版
- 第十三周项目3-成绩处理函数版
- 第十三周项目3-成绩处理函数版
- 第十三周 项目3:成绩处理函数版
- 第十三周上机项目3 成绩处理函数版
- 第十三周项目3-成绩处理函数版
- 第十三周项目3-成绩处理函数版
- 第十三周项目三(函数版成绩处理)
- 第十三周 项目三:成绩处理函数版
- 第十三周项目三——成绩处理函数版
- 第十三周项目三成绩处理函数版
- 第十三周 项目三-成绩处理函数版
- 第十三周项目三 成绩处理函数版
- 第十三周项目三——成绩处理函数版
- 第十三周项目三:成绩处理函数版
- 第13周 项目1-数组大折腾(4)
- c/c++基础(十四) 初步认识gcc
- 专家教你如何轻松解密Md5
- Unity 平台区分
- BZOJ 3754 Tree之最小方差树 MST
- 第十三周项目3 函数版成绩处理(返回)
- 判断回文
- 十道海量数据处理面试题与十个方法大总结
- dubbo 安装手册(修订)
- android 各个span类详解--用于富文本编排 下
- 《网络协议》数据链路层
- 关于: 安卓能否与iphone通过蓝牙4.0(BLE)通讯?
- C++文件输出输入
- 号被盗了