0
点赞
收藏
分享

微信扫一扫

成绩处理-xdoj

程序猿不脱发2 2022-02-14 阅读 39

标题

成绩处理

描述

输入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);
}
举报

相关推荐

字符删除-xdoj

密码强度-xdoj

单词排序-xdoj

xdoj 元素放置

XDOJ-84-目录操作

XDOJ67查找元素

xdoj字符串查找

0 条评论