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

news2025/1/15 7:02:16

学生成绩管理系统

  • 一、实现思路
  • 二、代码的实现
    • (1)构造功能框架
    • (2)实现各项功能
  • 三、完整的代码
  • 四、总结

本篇博客介绍一个关于学生成绩管理系统的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语言的学生成绩管理系统的实现,它可以让用户对学生的相关信息进行新增、删除、修改和查询等操作。该系统的主要功能模块包括登录、菜单选择、添加学生、删除学生、修改学生信息、查询学生信息以及退出系统等,用户可以通过选择不同的菜单选项,进入系统的不同功能模块进行操作。

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/628813.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

快速实现一个分布式定时器

定时器&#xff08;Timer&#xff09;是一种在业务开发中常用的组件&#xff0c;主要用在执行延时通知任务上。本文以笔者在工作中的实践作为基础&#xff0c;介绍如何使用平时部门最常用的组件快速实现一个业务常用的分布式定时器服务。同时介绍了过程中遇到问题的一些解决方案…

手机越狱:探索自由与风险的边界

&#x1f604;作者简介&#xff1a; 小曾同学.com,一个致力于测试开发的博主⛽️&#xff0c;主要职责&#xff1a;测试开发、CI/CD 如果文章知识点有错误的地方&#xff0c;还请大家指正&#xff0c;让我们一起学习&#xff0c;一起进步。&#x1f60a; 座右铭&#xff1a;不想…

100天精通Golang(基础入门篇)——第5天: Go语言中的数据类型学习

&#x1f337; 博主 libin9iOak带您 Go to Golang Language.✨ &#x1f984; 个人主页——libin9iOak的博客&#x1f390; &#x1f433; 《面试题大全》 文章图文并茂&#x1f995;生动形象&#x1f996;简单易学&#xff01;欢迎大家来踩踩~&#x1f33a; &#x1f30a; 《I…

htmlCSS-----盒模型

目录 前言&#xff1a; 盒子 1.内容区域 2. 边框 3. 内边距区域 4. 外边距区域&#xff08;margin&#xff09; 怪异盒模型 前言&#xff1a; 前面我们学习了CSS中的选择器的使用方法&#xff0c;那这一节我们就学习CSS中的盒模型&#xff0c;通过盒模型我们可以去更好的…

uni-app引入html2canvas截图以及截长图

下载安装html2canvas 方式一&#xff0c;https://www.bootcdn.cn/ CDN网站下载html2canvas插件 这里下载后放在测项目目录common下面 页面中引入 方式二、npm方式安装html2canvas 1、npm方式下载 npm i html2canvas2、引入html2canvas import html2canvas from html2can…

数据结构——广义表

文章目录 前言二、特殊矩阵的压缩存储数组的存储结构和实现按行优先存储按列优先存储 矩阵的压缩存储稀疏矩阵 广义表 总结 前言 数组&#xff0c;数组的压缩存储&#xff0c;广义表 二、特殊矩阵的压缩存储 数组的存储结构和实现 对于多维数组&#xff0c;可以分为按行优先…

UnityVR--组件9--视频组件VideoPlayer

目录 前言 参数解释 RenderMode渲染方式 VideoPlayer类中的API 前言 在之前的VR场景中已经使用过VideoPlayer播放视频&#xff08;Unity.UI的交互&#xff08;6&#xff09;-播放视频&#xff09;&#xff0c;不过在VR中设置是有些不同的&#xff0c;这里更详细地说明一下V…

8.面向对象编程(高级部分)|Java学习笔记

文章目录 类变量和类方法类变量类变量使用注意事项和细节 类方法类方法使用注意事项和细节 理解 main 方法语法代码块代码块使用注意事项和细节讨论 单例设计模式单例模式应用实例饿汉式 VS 懒汉式 final 关键字final 使用注意事项和细节 抽象类抽象类的介绍抽象类使用的注意事…

软件测试|测试金字塔是什么,它的目的是什么,以及它包含哪些层次?

一、测试金字塔的概念&#xff1a; 测试金字塔是2009年Mike Cohn在他的著作《Succeeding with Agile》一书正式提出的。他是一个类比的概念&#xff0c;形容每一层&#xff0c;或者说不同集成阶段测试覆盖率和知行效率之间的一个相对关系。 测试金字塔最初的原型分三层&#…

chatgpt赋能python:Python循环间隔-了解如何在循环中增加延时

Python循环间隔 - 了解如何在循环中增加延时 在Python编程中&#xff0c;循环是非常常见且重要的控制语句。 它使我们可以多次执行代码块。 但是&#xff0c;在有些情况下&#xff0c;您可能需要在循环之间增加一定的延时时间。 这就是Python循环间隔的概念。 在本文中&#x…

初次使用PPYOLOE-R

目的&#xff1a;优化基于yolov5-obb旋转目标检测算法的证件区域检测&#xff0c;之前的方法是基于anchor&#xff0c;每次使用都要调试anchor&#xff1b;而ppyoloe-r是free anchor的算法&#xff1b; 源码位置&#xff1a;https://github.com/PaddlePaddle/PaddleDetection/…

学成在线----day2

1、mybatis-plus分页 pom: <?xml version"1.0" encoding"UTF-8"?> <project xmlns"http://maven.apache.org/POM/4.0.0" xmlns:xsi"http://www.w3.org/2001/XMLSchema-instance"xsi:schemaLocation"http://maven.ap…

【大数据之Hive】九、Hive之DDL(Data Definition Language)数据定义语言

1 数据库 [ ] 里的都是可选的操作。 1.1 创建数据库 语法&#xff1a; create database [if not exists] database_name [comment database_comment(注释)] [location hdfs_path] [with dbproperties (property_name-propertyproperty_value,...)]; 如&#xff1a; creat…

真实性能测试案例之性能分析与报告

今天主要跟大家分享一个曾经所做的真实性能测试的案例&#xff0c;主要为其中性能测试分析报告过程部分&#xff0c;希望能对你以后怎么做性能分析和报告有所帮助。这个案例的测试目的为&#xff1a;在线考试为“XX平台”中的一个重要模块&#xff0c;根据目前业务的需要&#…

ChatGPT实用使用指南 让它解你所问

Chatgpt无疑是这几年来影响力最大的AI技术之一&#xff0c;生成式的AI模型正在促进各个行业的效率和自动化发展&#xff0c;Chatgpt对于个人、企业和各个行业都有着一定的影响 在我刚接触的时候&#xff0c;发现对Chatgpt的认知太肤浅了&#xff0c;一个最强的ai聊天机器人摆在…

实时检测Aruco标签坐标及位姿opencv-python4.6和4.7版本

先说opencv-contrib-python4.7.0.72时&#xff0c;aruco下面带曲线&#xff0c;但是程序也能跑&#xff0c;可以跑检测的&#xff0c;对比4.6版本需要改三个函数 4.6装opencv-contrib-python 4.7装opencv-contrib-python 1 cv2.aruco.Dictionary_get() cv2.aruco.getPredef…

Smali的使用技巧:快速定位Android应用程序中的关键代码

简述 Smali是一种Android应用程序的Dalvik虚拟机指令集汇编语言&#xff0c;用于编写和修改应用程序的DEX文件。通过编写和修改Smali代码&#xff0c;可以实现对Android应用程序的定制化和逆向分析。Smali语言类似于汇编语言&#xff0c;直接操作Dalvik虚拟机指令集。 Smali代…

2023最火的软件测试面试宝典,你刷过没?

这是一份最近疯传的软件测试面试宝典&#xff0c;你有刷过吗&#xff1f; 面试宝典一共400页&#xff0c;包括了测试基础102页&#xff0c;Linux基础38页&#xff0c;MySQL63页&#xff0c;web测试21页&#xff0c;app测试38页&#xff0c;selenium相关50页&#xff0c;性能测试…

02.引擎架构分类

简介 1.工具层 2.功能层&#xff1a;绘制、渲染、让世界里面的东西能看见、动起来 3.资源层&#xff1a;负责加载大量的数据和文件 4.核心层&#xff1a;游戏引擎的瑞士军刀&#xff0c;各种功能处理的内核 5.平台层&#xff1a;用于适配游戏不同的发行平台 第三方中间插…

3d渲染时预览和出图不一样怎么办?

在使用3dmax渲染时有时会遇到看到的图和渲染出来的图不一样的情况&#xff0c;这是为什么呢&#xff1f;有以下几方面的原因。 一、伽马 3dmax的伽马有很多&#xff0c;主要有显示伽马、输入伽马和输出伽马&#xff0c;其中预览图亮度由显示伽马决定&#xff0c;而图片亮度由输…