C语言——练习:登记学生成绩并计算平均成绩

登记两个班级学生的成绩,并计算平均成绩。

代码如下:

cpp 复制代码
#include<stdio.h>

void regisGrade(int array[],int len)  //自定义函数时,不同类型形参之间应使用,而不是;
{
	int i;
	
	
	for(i=0;i<len;i++){
		printf("请输入第%d个学生的成绩:",i+1);
		scanf("%d",&array[i]);
	}
	puts("done!");
}

void printGrade(int array[],int len)
{
	int i;
	
	printf("共有%d个学生,成绩分别为:",len);
	for(i=0;i<len;i++){
		printf("%d ",array[i]);
	}
	puts("\ndone!");
}

float getAver(int array[],int len)
{
	int i;
	int sumGrade = 0;          //总成绩必须初始化为0,默认值可能非0影响计算结果
	float averGrade;           //平均成绩使用浮点数进行表示
	
	for(i=0;i<len;i++){
		sumGrade = sumGrade + array[i];
	}
	averGrade = (float)sumGrade/len;
	return averGrade;
}

int main()
{
    int classOfOne[3];
	int classOfTwo[5];
	int lenOfClassOne = sizeof(classOfOne)/sizeof(classOfOne[0]);
	int lenOfClassTwo = sizeof(classOfTwo)/sizeof(classOfTwo[0]);
	float averClassOne;
	float averClassTwo;
	
	regisGrade(classOfOne,lenOfClassOne);  //数组作为形参调用时,在调用函数中不带[]
	regisGrade(classOfTwo,lenOfClassTwo);
	
	printGrade(classOfOne,lenOfClassOne);
	printGrade(classOfTwo,lenOfClassTwo);
	
	averClassOne = getAver(classOfOne,lenOfClassOne);  
	averClassTwo = getAver(classOfTwo,lenOfClassTwo);
	
	printf("一班的平均成绩为:%.3f\n",averClassOne);  //调用函数返回值为浮点数,注意输出应为%f
	printf("二班的平均成绩为:%.3f\n",averClassTwo);
	
	return 0;
}

输出将是:

cpp 复制代码
请输入第1个学生的成绩:98
请输入第2个学生的成绩:95
请输入第3个学生的成绩:95
done!
请输入第1个学生的成绩:68
请输入第2个学生的成绩:88
请输入第3个学生的成绩:87
请输入第4个学生的成绩:98
请输入第5个学生的成绩:99
done!
共有3个学生,成绩分别为:98 95 95
done!
共有5个学生,成绩分别为:68 88 87 98 99
done!
一班的平均成绩为:96.000
二班的平均成绩为:88.000

注意:

1.自定义函数时,不同类型形参之间应使用,而不是;即:

cpp 复制代码
void regisGrade(int array[],int len) 

而不是:

cpp 复制代码
void regisGrade(int array[];int len) 

2.平均成绩使用浮点数进行表示,则进行变量定义的时候应该定义为浮点型变量。且进行输出是也应该使用%f进行输出,同时在计算时使用(float)强制转换,把两个整数相除结果转换为小数。

3.数组作为形参调用时,在调用函数中不带[]即应该为:

cpp 复制代码
regisGrade(classOfOne,lenOfClassOne);

而不是:

cpp 复制代码
regisGrade(classOfOne[],lenOfClassOne);
相关推荐
AIAdvocate29 分钟前
Pandas_数据结构详解
数据结构·python·pandas
jiao000011 小时前
数据结构——队列
c语言·数据结构·算法
kaneki_lh1 小时前
数据结构 - 栈
数据结构
铁匠匠匠1 小时前
从零开始学数据结构系列之第六章《排序简介》
c语言·数据结构·经验分享·笔记·学习·开源·课程设计
C-SDN花园GGbond1 小时前
【探索数据结构与算法】插入排序:原理、实现与分析(图文详解)
c语言·开发语言·数据结构·排序算法
迷迭所归处2 小时前
C++ —— 关于vector
开发语言·c++·算法
leon6252 小时前
优化算法(一)—遗传算法(Genetic Algorithm)附MATLAB程序
开发语言·算法·matlab
CV工程师小林2 小时前
【算法】BFS 系列之边权为 1 的最短路问题
数据结构·c++·算法·leetcode·宽度优先
Navigator_Z3 小时前
数据结构C //线性表(链表)ADT结构及相关函数
c语言·数据结构·算法·链表
还听珊瑚海吗3 小时前
数据结构—栈和队列
数据结构