成绩处理函数版
来源:互联网 发布:电信网络电视连接不上 编辑:程序博客网 时间:2024/05/16 18:17
问题及代码:
烟台大学计算机与控制工程学院
作者:毕春超
完成日期:2016年12月5日
题目描述
在数组score中将要存储了某小组C程序设计的成绩,请设计实现下面的各功能函数,并在main函数中调用,组合成一个完整的应用:
(1)输入小组人数及成绩,要保证成绩在0-100之间;
(2)输出该小组的最高成绩、最低成绩、平均成绩;
(3)输出考得最高成绩和最低成绩的同学的人数;
(4)输出考得最高成绩和最低成绩的同学的学号(设数组下标即学号,可能有相同的成绩)。
(5)求出所有同学成绩的标准偏差,标准偏差公式为,其中
#include <stdio.h>
#include<math.h>
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( )
{
int score[50]; //将score设为局部变量,通过数组名作函数参数,传递数组首地址,在函数中操作数组
int num; //小组人数也设为局部变量,将作为函数的实际参数
int max_score,min_score;
printf("小组共有多少名同学? ");
scanf("%d", &num);
printf("请输入学生成绩:\n");
input_score(score, num); //要求成绩在0-100之间
max_score=get_max_score(score, num);
printf("最高成绩为:%d,共有 %d 人\n", max_score, count(max_score, score, num ));
min_score=get_min_score(score, num);
printf("最低成绩为:%d,共有 %d 人\n", min_score, count(min_score,score, num ));
printf("平均成绩为:%.2f\n", get_avg_score(score, num));
printf("标准偏差为:%.2f\n",get_stdev_score(score, num));
printf("获最高成绩的学生(学号)有:");
output_index(max_score,score, num);
printf("\n获最低成绩的学生(学号)有:");
output_index(min_score,score, num);
printf("\n");
return 0;
}
void input_score(int s[], int n)
{
int i;
for(i=0; i<n; i++)
do
{
printf("输入第 %d 位同学的成绩:", i);
scanf("%d", &s[i]);
}
while(s[i]<0||s[i]>100);
return;
}
int get_max_score(int s[], int n)
{
int max = -1;
int i;
for(i=0; i<n; i++)
if(max<s[i]) max= s[i];
return max;
}
int get_min_score(int s[], int n)
{
int min = 999;
int i;
for(i=0; i<n; i++)
if(min>s[i]) min= s[i];
return min;
}
double get_avg_score(int s[], int n)
{
double sum = 0;
int i;
for(i=0; i<n; i++)
sum+=s[i];
return sum/n;
}
double get_stdev_score(int s[], int n)
{
double sum = 0,mean_score, x;
int i;
mean_score =get_avg_score(s,n);
for(i=0; i<n; i++)
{
x=s[i]-mean_score;
sum+=x*x;
}
return sqrt(sum/(n-1));
}
int count(int m, int s[], int n)
{
int iCount=0;
int i;
for(i=0; i<n; i++)
{
if(s[i]==m)
iCount++;
}
return iCount;
}
void output_index(int m, int s[], int n)
{
int i;
for(i=0; i<n; i++)
{
if(s[i]==m)
printf("%d ", i);
}
return;
}
运算结果
- 成绩处理函数版
- 成绩处理函数版
- 成绩处理函数版
- 成绩处理函数版
- 成绩处理函数版
- 成绩处理函数版
- 成绩处理函数版
- 成绩处理函数版
- 练习,成绩处理函数版
- 14-3成绩处理函数版
- 学生成绩处理(函数版)
- 项目3成绩处理函数版
- 第十三周项目成绩处理函数版
- 项目三-成绩处理函数版
- 提高项目13-成绩处理 函数版
- 第十四周-成绩处理函数版
- 14--3成绩处理函数
- 第十四周——成绩处理函数版
- 跟小马哥学算法leetcode_09
- 最小生成树
- eclipse总是build,解决方法总结
- java切割wav音频文件
- jmp far ptr 标号
- 成绩处理函数版
- super()与this()的区别?
- [转]mysql group by 用法解析(详细)
- 前端--React-tutorial(入门书籍)
- Android RecyclerView 真正的布局刷新的正确方式
- HDOJ 2066 一个人的旅行(Dijstra 类似多源最短路)
- 64bit windows odbc
- ProtocolBuffer ObjectiveC配置使用
- ADB can't work