XDOJ - 成绩处理
描述:
输入5个学生,4门课成绩,二维数组stu[5][4]表示,行标表示学生,列标表示课程成绩,分别编写函数aver()、fals()和well()完成:(1)求第一门课的平均分;(2)统计有2门以上课程不及格的同学人数;(3)平均成绩在90分以上或者全部课程成绩在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>
int main()
{
double aver(double s);
int fals(double *p,int m);
int well(double *p1,int num);
int i,j,fail,number;
double sum=0,average,stu[5][4];
for(i=0;i<5;i++)
for(j=0;j<4;j++)
scanf("%lf",&stu[i][j]);
for(i=0;i<5;i++)
sum=sum+stu[i][0];
average=aver(sum);
fail=fals(*stu,20);
number=well(*stu,20);
printf("%.1lf %d %d",average,fail,number);
return 0;
}
double aver(double s)
{
return (s/5);
}
int fals(double *p,int m)
{
int i=0,n=0,c=0,flag=0;
double *p_end;
p_end=p+m;
for(;p<p_end;p++)
{
i++;
if((*p)<60)
n++;
if(n>=2 && flag==0)
{
flag=1;
c++;
}
if(i%4==0)
{
n=0;
flag=0;
}
}
return (c);
}
int well(double *p1,int num)
{
double zongfen=0,pingjun;
int i=0,count=0,f=0;
double *p1_end;
p1_end=p1+num;
for(;p1<p1_end;p1++)
{
i++;
if(*p1<85) f=1;
zongfen=zongfen+(*p1);
if(i%4==0)
{
pingjun=zongfen/4;
if((pingjun>=90)||(f==0))
count++;
f=0;
zongfen=0;
}
}
return (count);
}