ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

xdoj成绩处理(字符串数组)(呕心沥血...)

2022-01-03 23:30:31  阅读:185  来源: 互联网

标签:... int double xdoj stu 数组 呕心沥血 成绩 输入


标题

成绩处理

描述

输入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>
void aver(double stu[][4])
{
	double(*p)[4];/*p指针是指向的大小为4的数组,所以定义函数时,
	输入的定义是double类型的数组 stu[][4]。输入的是数组的数组,
	单位变量是小数组,所以定义的括号里不是stu[5][4],这样的话
	相当于输入的不是变量而是定值*/
	double sum=0;
	for(p=stu;p<=&stu[4];p++)/*一定是&stu[0]!加取址符号!因为
	此时已经调用stu大数组的基本元素了。用p=stu也可以。*/
	{
		sum=sum+(*p)[0];
	}
	double ave;
	ave=sum/5;
	printf("%.1lf",ave);
}
int fals(double stu[][4])
{
	double(*p)[4];
	int flag,count1=0;
	int j=0;
	for(p=&stu[0];p<=&stu[4];p++)
	{
		flag=0;
		for(j=0;j<4;j++)
		{
			if((*p)[j]<60)//千万别忘加括号(*p)啊啊啊啊啊!
			{
				flag++;
			}
		}
		if(flag>=2)
		{
			count1++;
		}
	}
	return count1;
	
}
int well(double stu[][4])
{
	double(*p)[4];
	int flag,count2=0;
	int j=0;
	double individual_general;//算个人总成绩
	for(p=&stu[0];p<=&stu[4];p++)
	{
		flag=0;
		individual_general=0;
		for(j=0;j<4;j++)
		{
			if((*p)[j]<85)//千万别忘加括号(*p)啊啊啊啊啊!
			{
				flag++;
			}
			individual_general=individual_general+(*p)[j];
			
		}
		if(flag==0||(individual_general/4.0>=90.0))
		{
			count2++;
		}
		
	}
	return count2;

}
int main() {
	double stu[5][4];
	int i,j;
	for(i=0;i<5;i++)
	for(j=0;j<4;j++)
	scanf("%lf",&stu[i][j]);
	aver(stu);
	printf(" ");
	printf("%d ",fals(stu));//可以用数组名代替数组本身
	printf("%d",well(stu));
	return 0;
}

标签:...,int,double,xdoj,stu,数组,呕心沥血,成绩,输入
来源: https://blog.csdn.net/weixin_62083045/article/details/122294096

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有