第十三周项目3-成绩处理函数版
来源:互联网 发布:迷宫生成算法 编辑:程序博客网 时间:2024/06/17 22:35
/* *Copyright(c)2014,烟台大学计算机学院 *All rights reserved. *文件名称:test.cpp *作者:满星辰 *完成日期:2014年 11月 23日 *版本号: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,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;}
运行结果:
学习心得:
虽然自定义函数好像麻烦了些,但是这样能使我条理清晰
不容易混淆各个函数的功能,也更容易找出错误
0 0
- 第十三周项目成绩处理函数版
- 第十三周项目3-成绩处理函数版
- 第十三周项目 3 成绩处理函数版
- 第十三周项目3-成绩处理函数版
- 第十三周项目3-成绩处理函数版
- 第十三周项目3 函数版成绩处理(返回)
- 第十三周 项目3:成绩处理函数版
- 第十三周上机项目3 成绩处理函数版
- 第十三周项目3-成绩处理函数版
- 第十三周项目3-成绩处理函数版
- 第十三周 项目三:成绩处理函数版
- 第十三周项目三——成绩处理函数版
- 第十三周项目三成绩处理函数版
- 第十三周 项目三-成绩处理函数版
- 第十三周项目三 成绩处理函数版
- 第十三周项目三——成绩处理函数版
- 第十三周项目三:成绩处理函数版
- 第十三周项目三(函数版成绩处理)
- 第十三周项目——oj平台的问题(2)
- Leetcode_6_ZigZag Conversion
- 第十三周项目——oj平台的问题(3)
- C++内置函数
- 机器学习之旅-------Beginner
- 第十三周项目3-成绩处理函数版
- 联网问题:主机localhost不能定位
- D3DUSAGE详解
- Java reflect
- 第十三周项目4-数组的排序(1 冒泡排倒序)
- Lua语言中pairs和ipairs的区别
- 鸟书shell学习(三)shell脚本程序设计要点总结
- 对自己的差劲感悟
- 算法导论 31-1 二进制的gcd算法