第13周项目3-成绩处理函数版
2014-11-24 11:08
211 查看
问题及代码:
运行结果:
学习心得:
挺长的一段代码,在编写时要注意小细节。
/* *Copyright (c)2014,烟台大学计算机与控制工程学院 *All rights reserved. *文件名称:number.cpp *作 者:赵敏 *完成日期:2014年11月24日 *版 本 号:v1.0 * *问题描述:项目二。。。 */ #include<iostream> #include<cmath> using namespace std; //将小组中n名同学的成绩输入数组s void input_score(int s[], int n); 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) { int i; for(i=0;i<n;i++) { cout<<"输入第"<<i<<"位同学的成绩:"; cin>>s[i]; if(s[i]>100||s[i]<0) i--; } return; } int get_max_score(int s[], int 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) { 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) { double ave; int i,sum=0; for(i=0;i<n;i++) { sum+=s[i]; } ave=sum/n; return ave; } double get_stdev_score(int s[], int n) { int i,sump=0; double sd,p; for(i=0;i<n;i++) { p=s[i]-get_avg_score(s,n); sump+=p*p; } sd=sqrt(sump/(n-1)); return sd; } int count(int x, int s[], int n) { int i,m=0; for(i=0;i<n;i++) { if(s[i]==x) m++; } return m; } void output_index(int x, int s[], int n) { int i; for(i=0;i<n;i++) { if(x==s[i]) cout<<i<<" "; } return; }
运行结果:
学习心得:
挺长的一段代码,在编写时要注意小细节。
相关文章推荐
- 第13周项目3成绩处理(函数版)
- 第13周项目3-成绩处理函数版
- 第13周上机实践项目3——成绩处理函数版
- 第13周项目3 -成绩处理函数版
- 第13周 项目3 运用函数处理成绩
- 第13周项目3-成绩处理函数版
- 第13周项目3-成绩处理函数版
- 第13周 项目3-成绩处理函数版
- 第13周项目3成绩处理函数版
- 2014秋C++第13周项目3参考-成绩处理函数版
- 第13周项目3-成绩处理函数版
- 第13周项目3-成绩处理函数版
- 第13周项目2-成绩处理(1)
- 第13周项目2成绩处理
- 【数组】项目二。成绩处理(无学号版)(函数版)
- 第十四周 项目3--成绩处理(函数版)
- 第十三周项目三成绩处理函数版
- 第十三周项目三 成绩处理函数版
- 2014秋C++第13周项目2参考-成绩处理
- 第十三周项目三——成绩处理函数版