学生成绩管理系统(C语言)

本篇博客介绍一个关于学生成绩管理系统的C语言代码,包含读取成绩、计算各门课程的总分和平均分、按分数排序、按学号排序、按姓名排序、查找成绩等基本功能。

一、实现思路

1、定义STU结构体,存储学生的基本信息和成绩。

2、编写各个函数实现不同的功能,包括输入学生成绩、计算总分和平均分、排序、查找、统计分数段、输出到文件等。

3、在主函数中编写程序逻辑,按用户选择调用不同的函数,实现学生成绩管理系统的各项功能。

4、运行程序,查看输出结果或将结果存储到文件中,实现数据的长期保存和管理。

二、代码的实现

在开始之前需要创建三个文件:

test.c — 用来构建学生成绩管理系统的整体逻辑

student.h — 用来存放函数所需要的头文件和声明

student.c — 存放函数的主体

然后就可以来完成学生成绩管理系统的代码了

(1)构造功能框架

此步是将系统主要功能的算法框架建立出来(只是框架,不需要实现功能)
代码如下

int main()
{
	char  ch;
	int   n = 0, m = 0;
	STU   stu[STU_NUM];
	printf("Input student number(n<%d):", STU_NUM);
	scanf("%d", &n);
	printf("Input course number(m<=%d):", COURSE_NUM);
	scanf("%d", &m);
	while (1)
	{
		ch = Menu();					    // 显示菜单,并读取用户输入 		
		switch (ch)
		{
		case 1:ReadScore(stu, n, m);
			break;
		case 2: AverSumofEveryCourse(stu, n, m);
			break;
		case 3: AverSumofEveryStudent(stu, n, m);
			break;
		case 4: SortbyScore(stu, n, m, Descending);
			printf("\nSort in descending order by score:\n");
			PrintScore(stu, n, m);
			break;
		case 5: SortbyScore(stu, n, m, Ascending);
			printf("\nSort in ascending order by score:\n");
			PrintScore(stu, n, m);
			break;
		case 6: AsSortbyNum(stu, n, m);
			printf("\nSort in ascending order by number:\n");
			PrintScore(stu, n, m);
			break;
		case 7: SortbyName(stu, n, m);
			printf("\nSort in dictionary order by name:\n");
			PrintScore(stu, n, m);
			break;
		case 8: SearchbyNum(stu, n, m);
			break;
		case 9: SearchbyName(stu, n, m);
			break;
		case 10: StatisticAnalysis(stu, n, m);
			break;
		case 11:PrintScore(stu, n, m);
			break;
		case 12:WritetoFile(stu, n, m);
			break;
		case 13:ReadfromFile(stu, &n, &m);
			break;
		case 0: printf("End of program!");
			exit(0);
		default:printf("Input error!");
		}
	}
	return 0;
}

(2)实现各项功能

接下来,我们需要实现功能函数,如读取成绩、计算每个学生各门课程的总分和平均分、计算每门课程的总分和平均分等:

// 函数功能:输入n个学生的m门课成绩 
void  ReadScore(STU stu[], int n, int m)
{
	int i, j;
	printf("Input student's ID, name and score:\n");
	for (i = 0; i < n; i++)
	{
		printf("%d:", i + 1);
		scanf("%ld %s", &stu[i].num, stu[i].name);
		for (j = 0; j < m; j++) 
		{
			scanf("%f", &stu[i].score[j]);
		}
	}
}
// 函数功能:计算每个学生各门课程的总分和平均分 
void  AverSumofEveryStudent(STU stu[], int n, int m)
{
	int i, j;
	for (i = 0; i < n; i++)
	{
		stu[i].sum = 0;
		for (j = 0; j < m; j++)
		{
			stu[i].sum = stu[i].sum + stu[i].score[j];
		}
		stu[i].aver = m > 0 ? stu[i].sum / m : -1;
		printf("student %d: sum = %.0f, aver = %.0f\n", i + 1, stu[i].sum, stu[i].aver);
	}
}
// 函数功能:计算每门课程的总分和平均分 
void  AverSumofEveryCourse(STU stu[], int n, int m)
{
	int i, j;
	float sum[COURSE_NUM], aver[COURSE_NUM];
	memset(sum, 0, sizeof(sum)); // 将数组sum的全部元素初始化为0
	memset(aver, 0, sizeof(aver)); // 将数组aver的全部元素初始化为0
	for (i = 0; i < n; i++)
	{
		for (j = 0; j < m; j++)
		{
			sum[j] += stu[i].score[j];
		}
	}
	for (j = 0; j < m; j++) 
	{
		aver[j] = n > 0 ? sum[j] / n : -1;
		printf("Course %d: sum=%.0f, aver=%.2f\n", j + 1, sum[j], aver[j]);
	}
}

接着,我们需要实现按分数排序、按学号排序、按姓名排序的功能,这里使用选择法排序和交换法排序,代码如下:

// 函数功能:按选择法将数组sum的元素值排序 
void  SortbyScore(STU stu[], int n, int m, int (*compare)(float a, float b))
{
	int  i, j, k, t;
	for (i = 0; i < n - 1; i++)
	{
		k = i;
		for (j = i + 1; j < n; j++)
		{
			if ((*compare)(stu[j].sum, stu[k].sum)) k = j;
		}
		if (k != i)
		{
			for (t = 0; t < m; t++)             // 交换m门课程的成绩 
			{
				SwapFloat(&stu[k].score[t], &stu[i].score[t]);
			}
			SwapFloat(&stu[k].sum, &stu[i].sum);    // 交换总分 
			SwapFloat(&stu[k].aver, &stu[i].aver); // 交换平均分   
			SwapLong(&stu[k].num, &stu[i].num);     // 交换学号 
			SwapChar(stu[k].name, stu[i].name);     // 交换姓名 
		}
	}
}
// 使数据按升序排序 
int   Ascending(float a, float b)
{
	return a < b;     // 这样比较决定了按升序排序,如果a<b,则交换 
}
// 使数据按降序排序
int   Descending(float a, float b)
{
	return a > b;    // 这样比较决定了按降序排序,如果a>b,则交换 
}
// 交换两个单精度浮点型数据 
void  SwapFloat(float* x, float* y)
{
	float  temp;
	temp = *x;
	*x = *y;
	*y = temp;
}
// 交换两个长整型数据 
void  SwapLong(long* x, long* y)
{
	long   temp;
	temp = *x;
	*x = *y;
	*y = temp;
}
// 交换两个字符串 
void  SwapChar(char x[], char y[])
{
	char temp[MAX_LEN];
	strcpy(temp, x);
	strcpy(x, y);
	strcpy(y, temp);
}
// 函数功能:按选择法将数组num的元素值按从低到高排序 
void  AsSortbyNum(STU stu[], int n, int m)
{
	int  i, j, k, t;
	for (i = 0; i < n - 1; i++)
	{
		k = i;
		for (j = i + 1; j < n; j++)
		{
			if (stu[j].num < stu[k].num)
			{
				k = j;
			}
		}
		if (k != i)
		{
			for (t = 0; t < m; t++)
			{
				SwapFloat(&stu[k].score[t], &stu[i].score[t]);
			}
			SwapFloat(&stu[k].sum, &stu[i].sum);
			SwapFloat(&stu[k].aver, &stu[i].aver);
			SwapLong(&stu[k].num, &stu[i].num);
			SwapChar(stu[k].name, stu[i].name);
		}
	}
}
// 函数功能:交换法实现字符串按字典顺序排序 
void  SortbyName(STU stu[], int n, int m)
{
	int  i, j, t;
	for (i = 0; i < n - 1; i++)
	{
		for (j = i + 1; j < n; j++)
		{
			if (strcmp(stu[j].name, stu[i].name) < 0)
			{
				for (t = 0; t < m; t++)// 交换m门课程的成绩 
				{
					SwapFloat(&stu[i].score[t], &stu[j].score[t]);
				}
				SwapFloat(&stu[i].sum, &stu[j].sum);    // 交换总分 
				SwapFloat(&stu[i].aver, &stu[j].aver); // 交换平均分   
				SwapLong(&stu[i].num, &stu[j].num);     // 交换学号 
				SwapChar(stu[i].name, stu[j].name);     // 交换姓名 
			}
		}
	}
}

最后,我们实现查找成绩、统计分数段人数及百分比、输出成绩到文件、从文件中读取成绩等功能:

// 函数功能:按学号查找学生成绩并显示查找结果 
void  SearchbyNum(STU stu[], int n, int m)
{
	long  number;
	int   i, j;
	printf("Input the number you want to search:");
	scanf("%ld", &number);
	for (i = 0; i < n; i++)
	{
		if (stu[i].num == number)
		{
			printf("%ld\t%s\t", stu[i].num, stu[i].name);
			for (j = 0; j < m; j++)
			{
				printf("%.0f\t", stu[i].score[j]);
			}
			printf("%.0f\t%.0f\n", stu[i].sum, stu[i].aver);
			return;
		}
	}
	printf("\nNot found!\n");
}
// 函数功能:按姓名的字典顺序排出成绩表 
void  SearchbyName(STU stu[], int n, int m)
{
	char x[MAX_LEN];
	int  i, j;
	printf("Input the name you want to search:");
	scanf("%s", x);
	for (i = 0; i < n; i++)
	{
		if (strcmp(stu[i].name, x) == 0)
		{
			printf("%ld\t%s\t", stu[i].num, stu[i].name);
			for (j = 0; j < m; j++)
			{
				printf("%.0f\t", stu[i].score[j]);
			}
			printf("%.0f\t%.0f\n", stu[i].sum, stu[i].aver);
			return;
		}
	}
	printf("\nNot found!\n");
}
// 函数功能:统计各分数段的学生人数及所占的百分比 
void  StatisticAnalysis(STU stu[], int n, int m)
{
	int  i, j, t[6];
	for (j = 0; j < m; j++)
	{
		printf("For course %d:\n", j + 1);
		memset(t, 0, sizeof(t));    // 将数组t的全部元素初始化为0 
		for (i = 0; i < n; i++)
		{
			if (stu[i].score[j] >= 0 && stu[i].score[j] < 60)t[0]++;
			else if (stu[i].score[j] < 70)				   t[1]++;
			else if (stu[i].score[j] < 80)				   t[2]++;
			else if (stu[i].score[j] < 90)				   t[3]++;
			else if (stu[i].score[j] < 100)				   t[4]++;
			else if (stu[i].score[j] == 100)    		   t[5]++;
		}
		for (i = 0; i <= 5; i++)
		{
			if (i == 0) printf("<60\t%d\t%.2f%%\n", t[i], (float)t[i] / n * 100);
			else if (i == 5) printf("%d\t%d\t%.2f%%\n",
				(i + 5) * 10, t[i], (float)t[i] / n * 100);
			else 	printf("%d-%d\t%d\t%.2f%%\n",
				(i + 5) * 10, (i + 5) * 10 + 9, t[i], (float)t[i] / n * 100);
		}
	}
}
// 函数功能: 打印学生成绩 
void  PrintScore(STU stu[], int n, int m)
{
	int i, j;
	for (i = 0; i < n; i++)
	{
		printf("%ld\t%s\t", stu[i].num, stu[i].name);
		for (j = 0; j < m; j++)
		{
			printf("%.0f\t", stu[i].score[j]);
		}
		printf("%.0f\t%.0f\n", stu[i].sum, stu[i].aver);
	}
}
// 输出n个学生的学号、姓名及m门课程的成绩到文件student.txt中 
void  WritetoFile(STU stu[], int n, int m)
{
	FILE* fp;
	int i, j;

	if ((fp = fopen("student.txt", "w")) == NULL)
	{
		printf("Failure to open score.txt!\n");
		exit(0);
	}
	fprintf(fp, "%d\t%d\n", n, m);    //将学生人数和课程门数写入文件
	for (i = 0; i < n; i++)
	{
		fprintf(fp, "%10ld%10s", stu[i].num, stu[i].name);
		for (j = 0; j < m; j++)
		{
			fprintf(fp, "%10.0f", stu[i].score[j]);
		}
		fprintf(fp, "%10.0f%10.0f\n", stu[i].sum, stu[i].aver);
	}
	fclose(fp);
}
//从文件中读取学生的学号、姓名及成绩等信息写入到结构体数组stu中
void   ReadfromFile(STU stu[], int* n, int* m)
{
	FILE* fp;
	int i, j;
	if ((fp = fopen("student.txt", "r")) == NULL)
	{
		printf("Failure to open score.txt!\n");
		exit(0);
	}
	fscanf(fp, "%d\t%d", n, m); // 从文件中读出学生人数和课程门数       
	for (i = 0; i < *n; i++)  //学生人数保存在n指向的存储单元
	{
		fscanf(fp, "%10ld", &stu[i].num);
		fscanf(fp, "%10s", stu[i].name);
		for (j = 0; j < *m; j++)//课程门数保存在m指向的存储单元
		{
			fscanf(fp, "%10f", &stu[i].score[j]);          //不能用%10.0f
		}
		fscanf(fp, "%10f%10f", &stu[i].sum, &stu[i].aver);//不能用%10.0f
	}
	fclose(fp);
}

三、完整的代码

student.h中的代码

#include  <stdio.h>
#include  <stdlib.h>
#include  <string.h>
#define   MAX_LEN  10                    	// 字符串最大长度 
#define   STU_NUM 30                       // 最多的学生人数 
#define   COURSE_NUM 6                     // 最多的考试科目数 
typedef struct student
{
	long num;						// 每个学生的学号 
	char name[MAX_LEN];            	// 每个学生的姓名 
	float score[COURSE_NUM];		// 每个学生COURSE_NUM门功课的成绩 
	float sum;                   	// 每个学生的总成绩 
	float aver;               	    // 每个学生的平均成绩 
}STU;


//  函数功能:显示菜单并获得用户键盘输入的选项 
int Menu(void);
// 函数功能:输入n个学生的m门课成绩 
void  ReadScore(STU stu[], int n, int m);
// 函数功能:计算每个学生各门课程的总分和平均分 
void  AverSumofEveryStudent(STU stu[], int n, int m);
// 函数功能:计算每门课程的总分和平均分 
void  AverSumofEveryCourse(STU stu[], int n, int m);
// 函数功能:按选择法将数组sum的元素值排序 
void  SortbyScore(STU stu[], int n, int m, int (*compare)(float a, float b));
// 使数据按升序排序 
int   Ascending(float a, float b);
// 使数据按降序排序
int   Descending(float a, float b);
// 交换两个单精度浮点型数据 
void  SwapFloat(float* x, float* y);
// 交换两个长整型数据 
void  SwapLong(long* x, long* y);
// 交换两个字符串 
void  SwapChar(char x[], char y[]);
// 函数功能:按选择法将数组num的元素值按从低到高排序 
void  AsSortbyNum(STU stu[], int n, int m);
// 函数功能:交换法实现字符串按字典顺序排序 
void  SortbyName(STU stu[], int n, int m);
// 函数功能:按学号查找学生成绩并显示查找结果 
void  SearchbyNum(STU stu[], int n, int m);
// 函数功能:按姓名的字典顺序排出成绩表 
void  SearchbyName(STU stu[], int n, int m);
// 函数功能:统计各分数段的学生人数及所占的百分比 
void  StatisticAnalysis(STU stu[], int n, int m);
// 函数功能: 打印学生成绩 
void  PrintScore(STU stu[], int n, int m);
// 输出n个学生的学号、姓名及m门课程的成绩到文件student.txt中 
void  WritetoFile(STU record[], int n, int m);
//从文件中读取学生的学号、姓名及成绩等信息写入到结构体数组stu中
void   ReadfromFile(STU record[], int* n, int* m);

student.c中的代码

#include "student.h"

//  函数功能:显示菜单并获得用户键盘输入的选项 
int Menu(void)
{
	int itemSelected;
	printf("Management for Students' scores\n");
	printf("1.Input record\n");
	printf("2.Calculate total and average score of every course\n");
	printf("3.Calculate total and average score of every student\n");
	printf("4.Sort in descending order by score\n");
	printf("5.Sort in ascending order by score\n");
	printf("6.Sort in ascending order by number\n");
	printf("7.Sort in dictionary order by name\n");
	printf("8.Search by number\n");
	printf("9.Search by name\n");
	printf("10.Statistic analysis\n");
	printf("11.List record\n");
	printf("12.Write to a file\n");
	printf("13.Read from a file\n");
	printf("0.Exit\n");
	printf("Please Input your choice:");
	scanf("%d", &itemSelected); 	// 读入用户输入 
	return itemSelected;
}
// 函数功能:输入n个学生的m门课成绩 
void  ReadScore(STU stu[], int n, int m)
{
	int i, j;
	printf("Input student's ID, name and score:\n");
	for (i = 0; i < n; i++)
	{
		printf("%d:", i + 1);
		scanf("%ld %s", &stu[i].num, stu[i].name);
		for (j = 0; j < m; j++) 
		{
			scanf("%f", &stu[i].score[j]);
		}
	}
}
// 函数功能:计算每个学生各门课程的总分和平均分 
void  AverSumofEveryStudent(STU stu[], int n, int m)
{
	int i, j;
	for (i = 0; i < n; i++)
	{
		stu[i].sum = 0;
		for (j = 0; j < m; j++)
		{
			stu[i].sum = stu[i].sum + stu[i].score[j];
		}
		stu[i].aver = m > 0 ? stu[i].sum / m : -1;
		printf("student %d: sum = %.0f, aver = %.0f\n", i + 1, stu[i].sum, stu[i].aver);
	}
}
// 函数功能:计算每门课程的总分和平均分 
void  AverSumofEveryCourse(STU stu[], int n, int m)
{
	int i, j;
	float sum[COURSE_NUM], aver[COURSE_NUM];
	//for (i = 0; i < m; i++)
	//{
	//	sum[i] = 0;
	//	for (j = 0; j < n; j++)
	//	{
	//		sum[i] += stu[j].score[i];
	//	}
	//	aver[i] = m > 0 ? sum[i] / m : -1;
	//}
	memset(sum, 0, sizeof(sum)); // 将数组sum的全部元素初始化为0
	memset(aver, 0, sizeof(aver)); // 将数组aver的全部元素初始化为0
	for (i = 0; i < n; i++)
	{
		for (j = 0; j < m; j++)
		{
			sum[j] += stu[i].score[j];
		}
	}
	for (j = 0; j < m; j++) 
	{
		aver[j] = n > 0 ? sum[j] / n : -1;
		printf("Course %d: sum=%.0f, aver=%.2f\n", j + 1, sum[j], aver[j]);
	}
}
// 函数功能:按选择法将数组sum的元素值排序 
void  SortbyScore(STU stu[], int n, int m, int (*compare)(float a, float b))
{
	int  i, j, k, t;
	for (i = 0; i < n - 1; i++)
	{
		k = i;
		for (j = i + 1; j < n; j++)
		{
			if ((*compare)(stu[j].sum, stu[k].sum)) k = j;
		}
		if (k != i)
		{
			for (t = 0; t < m; t++)             // 交换m门课程的成绩 
			{
				SwapFloat(&stu[k].score[t], &stu[i].score[t]);
			}
			SwapFloat(&stu[k].sum, &stu[i].sum);    // 交换总分 
			SwapFloat(&stu[k].aver, &stu[i].aver); // 交换平均分   
			SwapLong(&stu[k].num, &stu[i].num);     // 交换学号 
			SwapChar(stu[k].name, stu[i].name);     // 交换姓名 
		}
	}
}
// 使数据按升序排序 
int   Ascending(float a, float b)
{
	return a < b;     // 这样比较决定了按升序排序,如果a<b,则交换 
}
// 使数据按降序排序
int   Descending(float a, float b)
{
	return a > b;    // 这样比较决定了按降序排序,如果a>b,则交换 
}
// 交换两个单精度浮点型数据 
void  SwapFloat(float* x, float* y)
{
	float  temp;
	temp = *x;
	*x = *y;
	*y = temp;
}
// 交换两个长整型数据 
void  SwapLong(long* x, long* y)
{
	long   temp;
	temp = *x;
	*x = *y;
	*y = temp;
}
// 交换两个字符串 
void  SwapChar(char x[], char y[])
{
	char temp[MAX_LEN];
	strcpy(temp, x);
	strcpy(x, y);
	strcpy(y, temp);
}
// 函数功能:按选择法将数组num的元素值按从低到高排序 
void  AsSortbyNum(STU stu[], int n, int m)
{
	int  i, j, k, t;
	for (i = 0; i < n - 1; i++)
	{
		k = i;
		for (j = i + 1; j < n; j++)
		{
			if (stu[j].num < stu[k].num)
			{
				k = j;
			}
		}
		if (k != i)
		{
			for (t = 0; t < m; t++)
			{
				SwapFloat(&stu[k].score[t], &stu[i].score[t]);
			}
			SwapFloat(&stu[k].sum, &stu[i].sum);
			SwapFloat(&stu[k].aver, &stu[i].aver);
			SwapLong(&stu[k].num, &stu[i].num);
			SwapChar(stu[k].name, stu[i].name);
		}
	}
}
// 函数功能:交换法实现字符串按字典顺序排序 
void  SortbyName(STU stu[], int n, int m)
{
	int  i, j, t;
	for (i = 0; i < n - 1; i++)
	{
		for (j = i + 1; j < n; j++)
		{
			if (strcmp(stu[j].name, stu[i].name) < 0)
			{
				for (t = 0; t < m; t++)// 交换m门课程的成绩 
				{
					SwapFloat(&stu[i].score[t], &stu[j].score[t]);
				}
				SwapFloat(&stu[i].sum, &stu[j].sum);    // 交换总分 
				SwapFloat(&stu[i].aver, &stu[j].aver); // 交换平均分   
				SwapLong(&stu[i].num, &stu[j].num);     // 交换学号 
				SwapChar(stu[i].name, stu[j].name);     // 交换姓名 
			}
		}
	}
}
// 函数功能:按学号查找学生成绩并显示查找结果 
void  SearchbyNum(STU stu[], int n, int m)
{
	long  number;
	int   i, j;
	printf("Input the number you want to search:");
	scanf("%ld", &number);
	for (i = 0; i < n; i++)
	{
		if (stu[i].num == number)
		{
			printf("%ld\t%s\t", stu[i].num, stu[i].name);
			for (j = 0; j < m; j++)
			{
				printf("%.0f\t", stu[i].score[j]);
			}
			printf("%.0f\t%.0f\n", stu[i].sum, stu[i].aver);
			return;
		}
	}
	printf("\nNot found!\n");
}
// 函数功能:按姓名的字典顺序排出成绩表 
void  SearchbyName(STU stu[], int n, int m)
{
	char x[MAX_LEN];
	int  i, j;
	printf("Input the name you want to search:");
	scanf("%s", x);
	for (i = 0; i < n; i++)
	{
		if (strcmp(stu[i].name, x) == 0)
		{
			printf("%ld\t%s\t", stu[i].num, stu[i].name);
			for (j = 0; j < m; j++)
			{
				printf("%.0f\t", stu[i].score[j]);
			}
			printf("%.0f\t%.0f\n", stu[i].sum, stu[i].aver);
			return;
		}
	}
	printf("\nNot found!\n");
}
// 函数功能:统计各分数段的学生人数及所占的百分比 
void  StatisticAnalysis(STU stu[], int n, int m)
{
	int  i, j, t[6];
	for (j = 0; j < m; j++)
	{
		printf("For course %d:\n", j + 1);
		memset(t, 0, sizeof(t));    // 将数组t的全部元素初始化为0 
		for (i = 0; i < n; i++)
		{
			if (stu[i].score[j] >= 0 && stu[i].score[j] < 60)t[0]++;
			else if (stu[i].score[j] < 70)				   t[1]++;
			else if (stu[i].score[j] < 80)				   t[2]++;
			else if (stu[i].score[j] < 90)				   t[3]++;
			else if (stu[i].score[j] < 100)				   t[4]++;
			else if (stu[i].score[j] == 100)    		   t[5]++;
		}
		for (i = 0; i <= 5; i++)
		{
			if (i == 0) printf("<60\t%d\t%.2f%%\n", t[i], (float)t[i] / n * 100);
			else if (i == 5) printf("%d\t%d\t%.2f%%\n",
				(i + 5) * 10, t[i], (float)t[i] / n * 100);
			else 	printf("%d-%d\t%d\t%.2f%%\n",
				(i + 5) * 10, (i + 5) * 10 + 9, t[i], (float)t[i] / n * 100);
		}
	}
}
// 函数功能: 打印学生成绩 
void  PrintScore(STU stu[], int n, int m)
{
	int i, j;
	for (i = 0; i < n; i++)
	{
		printf("%ld\t%s\t", stu[i].num, stu[i].name);
		for (j = 0; j < m; j++)
		{
			printf("%.0f\t", stu[i].score[j]);
		}
		printf("%.0f\t%.0f\n", stu[i].sum, stu[i].aver);
	}
}
// 输出n个学生的学号、姓名及m门课程的成绩到文件student.txt中 
void  WritetoFile(STU stu[], int n, int m)
{
	FILE* fp;
	int i, j;

	if ((fp = fopen("student.txt", "w")) == NULL)
	{
		printf("Failure to open score.txt!\n");
		exit(0);
	}
	fprintf(fp, "%d\t%d\n", n, m);    //将学生人数和课程门数写入文件
	for (i = 0; i < n; i++)
	{
		fprintf(fp, "%10ld%10s", stu[i].num, stu[i].name);
		for (j = 0; j < m; j++)
		{
			fprintf(fp, "%10.0f", stu[i].score[j]);
		}
		fprintf(fp, "%10.0f%10.0f\n", stu[i].sum, stu[i].aver);
	}
	fclose(fp);
}
//从文件中读取学生的学号、姓名及成绩等信息写入到结构体数组stu中
void   ReadfromFile(STU stu[], int* n, int* m)
{
	FILE* fp;
	int i, j;
	if ((fp = fopen("student.txt", "r")) == NULL)
	{
		printf("Failure to open score.txt!\n");
		exit(0);
	}
	fscanf(fp, "%d\t%d", n, m); // 从文件中读出学生人数和课程门数       
	for (i = 0; i < *n; i++)  //学生人数保存在n指向的存储单元
	{
		fscanf(fp, "%10ld", &stu[i].num);
		fscanf(fp, "%10s", stu[i].name);
		for (j = 0; j < *m; j++)//课程门数保存在m指向的存储单元
		{
			fscanf(fp, "%10f", &stu[i].score[j]);          //不能用%10.0f
		}
		fscanf(fp, "%10f%10f", &stu[i].sum, &stu[i].aver);//不能用%10.0f
	}
	fclose(fp);
}

test.c中的代码

#include "student.h"

int main()
{
	char  ch;
	int   n = 0, m = 0;
	STU   stu[STU_NUM];
	printf("Input student number(n<%d):", STU_NUM);
	scanf("%d", &n);
	printf("Input course number(m<=%d):", COURSE_NUM);
	scanf("%d", &m);
	while (1)
	{
		ch = Menu();					    // 显示菜单,并读取用户输入 		
		switch (ch)
		{
		case 1:ReadScore(stu, n, m);
			break;
		case 2: AverSumofEveryCourse(stu, n, m);
			break;
		case 3: AverSumofEveryStudent(stu, n, m);
			break;
		case 4: SortbyScore(stu, n, m, Descending);
			printf("\nSort in descending order by score:\n");
			PrintScore(stu, n, m);
			break;
		case 5: SortbyScore(stu, n, m, Ascending);
			printf("\nSort in ascending order by score:\n");
			PrintScore(stu, n, m);
			break;
		case 6: AsSortbyNum(stu, n, m);
			printf("\nSort in ascending order by number:\n");
			PrintScore(stu, n, m);
			break;
		case 7: SortbyName(stu, n, m);
			printf("\nSort in dictionary order by name:\n");
			PrintScore(stu, n, m);
			break;
		case 8: SearchbyNum(stu, n, m);
			break;
		case 9: SearchbyName(stu, n, m);
			break;
		case 10: StatisticAnalysis(stu, n, m);
			break;
		case 11:PrintScore(stu, n, m);
			break;
		case 12:WritetoFile(stu, n, m);
			break;
		case 13:ReadfromFile(stu, &n, &m);
			break;
		case 0: printf("End of program!");
			exit(0);
		default:printf("Input error!");
		}
	}
	return 0;
}

四、总结

以上代码是一个基于C语言的学生成绩管理系统的实现,它可以让用户对学生的相关信息进行新增、删除、修改和查询等操作。该系统的主要功能模块包括登录、菜单选择、添加学生、删除学生、修改学生信息、查询学生信息以及退出系统等,用户可以通过选择不同的菜单选项,进入系统的不同功能模块进行操作。

在这里插入图片描述

  • 38
    点赞
  • 85
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 27
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 27
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小全.

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值