当前位置: 代码迷 >> 综合 >> 成绩处理-xdoj
  详细解决方案

成绩处理-xdoj

热度:25   发布时间:2023-12-06 09:20:18.0

标题

成绩处理

描述

输入5个学生,4门课成绩,二维数组stu[5][4]表示,行标表示学生,列标表示课程成绩,分别编写函数aver()、fals()和well()完成:(1)求第一门课的平均分;(2)统计有2门以上(含2门)课程不及格的同学人数;(3)平均成绩在90分以上(含90分)或者全部课程成绩在85分以上(含85分)的同学视为优秀,统计人数,使用指针完成地址传递,主函数完成数组输入和输出。

  

时间限制

1    

内存限制

10000   

类别

1

输入说明

输入二维浮点型数组stu[5][4]

输出说明

输出第一门课程平均分(保留1位小数)、2门以上不及格人数和成绩优秀人数,数据之间空一格。

输入样例

85 73 59 92

93 95 89 88

86 88 88 87

59 51 52 68

78 32 59 91

输出样例

80.2 2 2

提示

注意行列信息。使用指针完成地址传递,主函数完成数组输入和输出。

#include<stdio.h>
double aver(double(*stu)[4])
{double p=0,q;int i;for(i=0;i<5;i++){p+=stu[i][0];//??????p+=*(stu+i)[0];}q=p/5;return q;
}
int fals(double(*stu)[4])
{int i,j,zan=0,sum=0;for(i=0;i<5;i++){zan=0;for(j=0;j<4;j++){if(stu[i][j]<60)zan++;}if(zan>=2)sum++;}return sum;
}
int well(double(*stu)[4])
{int i,j,sum=0,num;double all;for(i=0;i<5;i++){all=0;num=0;for(j=0;j<4;j++){all+=stu[i][j];if(stu[i][j]>=85)num++;	}if(all>=360||num==4)sum++;}return sum;
}
int main()
{int i,j;double a;int b,c;double stu[5][4]={0};for(i=0;i<5;i++)for(j=0;j<4;j++)scanf("%lf",&stu[i][j]);a=aver(stu);b=fals(stu);c=well(stu);printf("%.1lf %d %d",a,b,c);
}