C语言课程设计——学生成绩管理系统(完整项目超详细附源码+注释)基于链表和文件存储的学生成绩管理系统

目录

引言

一、设计理念与目标

二、系统功能概览

三、概要设计

四、详细设计

五、技术实现与挑战

六、运行结果及测试

 七、核心代码

八、结语


引言

在当今数字化教育日益普及的背景下,一个高效、灵活的学生成绩管理系统成为了教育机构不可或缺的工具。它不仅能帮助教师高效地跟踪学生的学习进展,还能为学生提供直观的成绩反馈,促进个性化学习的发展。本文旨在探讨如何设计并实现一个基于链表结构和文件存储功能的学生成绩管理系统,该系统能够满足多种实际需求,包括记录学生信息、成绩管理、成绩计算以及数据排序等。

一、设计理念与目标

本系统采用链表作为核心数据结构来存储学生信息及其成绩,主要基于以下几点考虑:

  • 灵活性:链表允许我们在不重新分配整个数据结构的情况下动态地添加、删除或修改节点,非常适合处理频繁变动的数据集合。
  • 内存效率:虽然链表在随机访问方面不如数组高效,但在数据元素数量不固定或需要频繁插入、删除操作时,链表能更有效地利用内存。
  • 文件存储:结合文件存储功能,系统能够将数据持久化到硬盘上,确保即使程序关闭,数据也不会丢失,同时便于数据备份和迁移。

二、系统功能概览

  1. 数据记录:每条记录包含学生的学号、姓名、专业以及五门课程的成绩,这些信息构成了系统的基本数据单元。
  2. 添加功能:系统应提供接口允许用户输入新学生的所有信息,并将其作为新节点添加到链表的末尾。
  3. 删除功能:用户可以根据学号或姓名查找并删除指定学生的记录,确保数据的准确性和时效性。
  4. 修改功能:允许用户修改已存在学生的部分或全部信息,如成绩更新等。
  5. 成绩计算:系统应能自动计算并显示指定学生的总分和平均分,帮助学生和教师快速了解学习状况。
  6. 排序输出:支持按总分对学生进行排序,并以列表形式输出排序后的结果,方便教师评估学生的整体表现。

三、概要设计

本设计是利用结构体实现学生成绩管理系统,系统包括添加学生信息模块、显示学生信息模块、学生信息查询模块、学生信息数据计算模块(含计算平均分和总分、排序)、修改学生信息模块、删除学生信息模块、保存退出模块和主函数等模块组成,总体结构图如图1所示。

图1 总体结构图

四、详细设计

从数据的存储结构、主要算法思想和各模块的设计几方面详细阐述设计过程。

(1)存储结构

用struct结构体储存学生信息,包括:

  1.  学号           char sum[20]
  2.  姓名           char num[20]
  3.  专业           char frofession[50]
  4.  语文成绩       float china
  5.  数学成绩       float math
  6.  英语成绩       float english
  7.  物理成绩       float physical
  8.  化学成绩       float chemical

(2)主要算法思想

  1. 结构体储存学生。
  2. 排序算法:选择排序法,首先从原始的数组中选择最小的1个数据,将其和位于第1个位置的数据交换,接着从剩下的n-1个数据中选择次小的数据,将其和第2个位置的数据交换,以此类推,这样不断的重复,直到最后的两个数据完成交换,便完成了对原始数组的从小到大的排序。

(3)各模块用到的函数及功能

本设计用到的功能函数如表1所示:

表1 各函数及功能

函数名

作用

login();

登录系统的界面

int menu_filename();

对文件名进行命名

int menu_select();

菜单选择系统

void add();

学生成绩录入与添加

void scan();

显示记录,进行全面信息浏览

void query();

按学生信息的不同方式查询

void date();

对学生数据计算与排序

void amend();

对学生成绩数据进行修改

void delet();

对学生成绩数据进行删除

五、技术实现与挑战

  • 链表操作:实现链表的创建、插入、删除和遍历等基本操作,确保数据操作的准确性和效率。
  • 文件I/O:设计合理的文件读写策略,包括数据的序列化与反序列化,确保数据的持久化和快速恢复。
  • 异常处理:增加错误处理和异常捕获机制,提高系统的健壮性和用户友好性。
  • 用户交互:设计简洁明了的用户界面或命令行接口,使用户能够方便地进行各项操作。

六、运行结果及测试

本设计首先从输入命名一个文件,对文件中内容读写开始测试,通过后逐个增加模块进行测试,最后使整个程序全部正常运行。

1.登录界面模块测试

如图2所示:

图2 登录界面

2.文件名输入模块测试


    输入“计科211成绩”对文件名进行命名,按回车挑战菜单选择界面。如图3、4所示:

图3 文件命名                                                                        图4 菜单界面

4.各模块功能测试

1)添加记录模块测试

输入“1”进入添加记录功能,根据要求输入对应数据,如图5所示:

图5 数据录入与添加

输入“y”或“n”选择是否继续添加,运行如图6、7所示:

图6 “y”继续添加

图7 “n”不继续添加

2)显示记录模块测试


在菜单选择界面输入“2”进入显示记录功能,运行如图8所示:

图8 显示记录

   浏览完全面信息后,会弹出是否修改信息功能,若输入“y”,运行如图9所示,

若输入“n”,运行结构跳回菜单界面如图4。

图9 选择修改信息

   选择修改信息的方式,输入“1”姓名修改方式如图10所示,输入“2”学号修改如图11所示,输入“3”则返回菜单界面如图4。

图10 姓名方式修改                                                     图11 学号方式修改

   非法测试:当选择修改方式时输入不恰当会提示“输入错误请重新修改”如果输入姓名或学号有误,系统将会提示“成绩系统中没有此人”,如图12所示。

图12 非法测试

3)信息查询模块测试

在菜单选择界面输入“3”进入信息查询功能,选择查询信息的方式,输入“1”姓名查询方式如图13所示,输入“2”学号查询如图14所示,输入“3”则返回菜单界面如图4。



图13 姓名方式查询                                                图14 学号方式查询

   非法测试与显示记录中非法测试相似,在此不重复概述。

4)数据计算模块测试

在菜单选择界面输入“4”进入数据计算功能,选择成绩排序的方式,输入各门课程成绩排序的相应编号“1-5”,进行成绩排序功能,其中编号“6”与“7”中先计算了学生的总分或平均分,再排序输出,如图15所示,输入“8”则返回菜单界面如图4。


图15 多种方式排序

非法测试与显示记录中非法测试相似,在此不重复概述。

5)修改记录模块测试

在菜单选择界面输入“5”进入修改记录功能,修改记录函数在显示记录功能中被调用过,详细测试请看“显示记录模块测试”。

6)删除记录模块测试

在菜单选择界面输入“6”进入删除记录功能,输入想要删除的学生学号即可删除其对应的信息,显示记录中则无该学生的相关信息,如图16所示。

图16 删除记录

7)退出程序模块测试

在菜单选择界面输入“7”进入退出程序功能,系统会提示“谢谢使用,bye!!!”在按任意键退出程序。如图17所示。


图17 退出程序

以上各个功能测试效果与输入的一样,测试通过。

 七、核心代码

1)成绩录入与添加函数
用结构体类型FILE定义一个文件,将录入与添加的数据都保存到此文件中,运用while结构来实现只有当输入N或n时才跳出添加数据。
代码如下:
void add()                                      
{
	FILE *fp;
	int i=0,n=0;
	char sign='y'; 
	system("cls"); 
	while(sign!='n'&&sign!='N')
    {
		printf("             ----学生记录添加----\n");
	    printf("学号:\n");
	    scanf("\t%s",stu[i].num);
	    printf("姓名:\n");
	    scanf("\t%s",stu[i].name);
	    printf("专业:\n");
	    scanf("\t%s",stu[i].profession);
	    printf("语文:\n");
	    scanf("\t%f",&stu[i].china);
	    printf("数学:\n");
	    scanf("\t%f",&stu[i].math);
	    printf("英语:\n");
	    scanf("\t%f",&stu[i].english);
	    printf("物理:\n");
	    scanf("\t%f",&stu[i].physical);
	    printf("化学:\n");
	    scanf("\t%f",&stu[i].chemical);
        printf("是否继续添加?(y/n)");
	    scanf("\t%c",&sign);
	    i++;
	    n=n+1;
	    system("cls");
    }system("pause");                                     
    if((fp=fopen(filename,"a"))==NULL)                    
	{
		printf("cannot open the files\n");
		system("pause");
        return; 
	}
	for(i=0;i<n;i++)
	if(fwrite(&stu[i],sizeof(STU),1,fp)!=1) 
	printf("file write error\n");
	fclose(fp);
	system("pasue");
}
2)显示数据函数
   对文件中的内容运用fread以二进制的方式将文件信息读到先前定义的结构体中数组内存中。在显示数据函数中声明数据修改函数,起到当用户在浏览全面信息后可选择是否对数据进行修改。
代码如下:
void scan()                        
{
	void amend();
	char sign='y';
	FILE *fp;
    int i=0,n;
    system("cls");
    if((fp=fopen(filename,"r"))==NULL)
	{
		printf("cannot open the files\n");
		system("pause");
        return;
	}
    while(!feof(fp))  //一直读取知道文件尾结束
	{
		fread(&stu[i],sizeof(STU),1,fp); 
		i++;
    }
    fclose(fp);
	printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
    printf("学号  姓名  专业   \t语文 \t数学  \t英语  \t物理  \t化学  \n");
	printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
    for(n=0;n<i-1;n++)  
    {
		printf("  %s \t%s \t%s\t%.2f   \t%.2f   \t%.2f   \t%.2f   \t%.2f\n",
		stu[n].num,stu[n].name,stu[n].profession,
		stu[n].china,stu[n].math,stu[n].english,stu[n].physical,stu[n].chemical);
    }
	printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
	system("pause");
	system("cls");
	printf("是否需要修改?(y/n)");
	scanf("\t%c",&sign);
	if(sign!='n'&&sign!='N')    //选择是否在浏览后进行修改//
		amend();
	system("pause");
}
3)成绩查询函数
   运用选择结构if来实现在文件对学生成绩查询可以有多种选择,如:学号,姓名。
代码如下:
void query()                     
{
	FILE *fp;
	int i=0,n=0;
	int m;
	system("cls");
	printf("\t\n请选择查询方式:\n");
    printf("\t┌────────┐\n");
    printf("\t│1------姓名 │\n");
    printf("\t│2------学号 │\n");
    printf("\t│3------返回 │\n");
    printf("\t└────────┘\n");
	printf("请输入你要查询的方式\n");
	scanf("%d",&m);
	while(m!=1&&m!=2&&m!=3)
	{
		printf("输入错误请重新查询\n");
	    scanf("%d",&m);
	}
    if((fp=fopen(filename,"r"))==NULL)             
	{
		printf("cannot open the files\n");
		system("pause");
        return;
	}
 
    while(!feof(fp))
	{
		fread(&stu[i],sizeof(STU),1,fp);                      
	    i++;n=n+1;
    }
    //姓名查询
	if(m==1)                                            
	{
		char s[20];
		int i=0;
		printf("\t请输入想查询的姓名:");
		scanf("\t%s",s);
		while(strcmp(stu[i].name,s)!=0&&i<n) 
		i++;            //比较stu[i].name与所输入姓名是否相同//
		if(i==n)
		{
			printf("\t成绩系统中没有此人!\n");
			system("pause");
			return;
		}
		printf("\t学号: %s\n",stu[i].num);
		printf("\t姓名: %s\n",stu[i].name);
		printf("\t专业: %s\n",stu[i].profession);
		printf("\语文: %.2f\n",stu[i].china);
		printf("\数学: %.2f\n",stu[i].math);
		printf("\英语: %.2f\n",stu[i].english);
		printf("\物理: %.2f\n",stu[i].physical);
		printf("\化学: %.2f\n",stu[i].chemical);
	}
	//学号查询
	if(m==2)                                                            
	{
		char s[20];
		int i=0;
		printf("请输入想查询的学号:");
		scanf("\t%s",s);
		while(strcmp(stu[i].num,s)!=0&&i<n)
		i++;                       //比较stu[i].sum与所输入学号是否相同//
		if(i==n)
		{
			printf("\t成绩系统中没有此人!\n");
			system("pause");
			return;
		}
		printf("\t学号: %s\n",stu[i].num);
		printf("\t姓名: %s\n",stu[i].name);
		printf("\t专业: %s\n",stu[i].profession);
		printf("\语文: %.2f\n",stu[i].china);
		printf("\数学: %.2f\n",stu[i].math);
		printf("\英语: %.2f\n",stu[i].english);
		printf("\物理: %.2f\n",stu[i].physical);
		printf("\化学: %.2f\n",stu[i].chemical);
	} 
		  fclose(fp);
		  system("pause");
}
4)数据统计函数
    同样运用了选择结构if来实现对学生成绩的多种排序,其中排序运用了选择排序法这种算法。在总分和平均分排序中先对同学的总分和平均分进行计算并按从小到大排序。
代码如下:
void date()
{
	FILE *fp;
	struct student temp;       //定义临时数组用于交换时存放数组信息用于后面的交换//
	float sum,aver;                              //总分,平均分 
	float s[100],ave[100];
    int i=0,n=0;
	int j,t;
	int m;
	system("cls");
	printf("\t\n选择排序方式:\n");
    printf("\t┌──────┐\n");
    printf("\t│1------语文 │\n");
    printf("\t│2------数学 │\n");
    printf("\t│3------英语 │\n");
    printf("\t│4------物理 │\n");
	printf("\t│5------化学 │\n");
	printf("\t│6------总分 │\n");
    printf("\t│7----平均分 │\n");
    printf("\t│8------返回 │\n");
    printf("\t└──────┘\n");
	printf("请输入你要排序的方式\n");
	scanf("%d",&m);
	system("cls");
	while(m!=1&&m!=2&&m!=3&&m!=4&&m!=5&&m!=6&&m!=7&&m!=8)
	{
		printf("输入错误请重新输入\n");
	    scanf("%d",&m);
	}
    if((fp=fopen(filename,"r"))==NULL)
	{
		printf("cannot open the files\n");
		system("pause");
        return;
	}
    while(!feof(fp)) 
	{
	   fread(&stu[i],sizeof(STU),1,fp);
	   i++;n=n+1;
    }
    //语文成绩排序 
    if(m==1)
	{
	  	for(i=0;i<n-1;i++)
	  	{
	    	for(j=i+1;j<n;j++)
	    	if(stu[j].china>stu[i].china)  
	    	{
				temp=stu[j];stu[j]=stu[i];stu[i]=temp; 
			}  
		}
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
    	printf("  学号  姓名  专业  \t语文  \t数学 \t英语 \t物理 \t化学  \n");
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
    	for(i=0;i<n-1;i++)                             
    	{
			printf("  %s \t%s \t%s\t%.2f   \t%.2f   \t%.2f   \t%.2f   \t%.2f\n",
			stu[i].num,stu[i].name,stu[i].profession,
	   stu[i].china,stu[i].math,stu[i].english,stu[i].physical,stu[i].chemical);
    	}
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
		fclose(fp);
	}
 	//数学成绩排序 
	if(m==2)
	  {
		for(i=0;i<n-1;i++)                          
	  	{
	    	for(j=i+1;j<n;j++)
	    	if(stu[j].math>stu[i].math)                              
	    	{
				temp=stu[j];stu[j]=stu[i];stu[i]=temp;  
			}                 
		}
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
    	printf("  学号  姓名  专业  \t语文  \t数学 \t英语 \t物理 \t化学  \n");
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
    	for(i=0;i<n-1;i++)                             
    	{
			printf("  %s \t%s \t%s\t%.2f   \t%.2f   \t%.2f   \t%.2f   \t%.2f\n",
			stu[i].num,stu[i].name,stu[i].profession,
	   stu[i].china,stu[i].math,stu[i].english,stu[i].physical,stu[i].chemical);
    	}
	printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
		fclose(fp);
	}
	//英语成绩排序 
	if(m==3)
	{
		for(i=0;i<n-1;i++)                           
	  	{
	    	for(j=i+1;j<n;j++)
	    	if(stu[j].english>stu[i].english)                              
	    	{
				temp=stu[j];stu[j]=stu[i];stu[i]=temp;  
			}                 
		}
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
    	printf("  学号  姓名  专业  \t语文  \t数学 \t英语 \t物理 \t化学  \n");
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
    	for(i=0;i<n-1;i++)                             
    	{
			printf("  %s \t%s \t%s\t%.2f   \t%.2f   \t%.2f   \t%.2f   \t%.2f\n",
			stu[i].num,stu[i].name,stu[i].profession,
	   stu[i].china,stu[i].math,stu[i].english,stu[i].physical,stu[i].chemical);
    	}
	printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
		fclose(fp);  	
	}
	//物理成绩排序 
 	if(m==4)
	{
		for(i=0;i<n-1;i++)                           
	  	{
	    	for(j=i+1;j<n;j++)
	    	if(stu[j].physical>stu[i].physical)                              
	    	{
				temp=stu[j];stu[j]=stu[i];stu[i]=temp;  
			}                 
		}
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
    	printf("  学号  姓名  专业  \t语文  \t数学 \t英语 \t物理 \t化学  \n");
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
    	for(i=0;i<n-1;i++)                             
    	{
			printf("  %s \t%s \t%s\t%.2f   \t%.2f   \t%.2f   \t%.2f   \t%.2f\n",
			stu[i].num,stu[i].name,stu[i].profession,
	   stu[i].china,stu[i].math,stu[i].english,stu[i].physical,stu[i].chemical);
    	}
	printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
		fclose(fp);
	}
	//化学成绩排序 
	if(m==5)
	{
		for(i=0;i<n-1;i++)                           
	  	{
	    	for(j=i+1;j<n;j++)
	    	if(stu[j].math>stu[i].math)                              
	    	{
				temp=stu[j];stu[j]=stu[i];stu[i]=temp;  
			}                 
		}
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
    	printf("  学号  姓名  专业  \t语文  \t数学 \t英语 \t物理 \t化学  \n");
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
    	for(i=0;i<n-1;i++)                             
    	{
			printf("  %s \t%s \t%s\t%.2f   \t%.2f   \t%.2f   \t%.2f   \t%.2f\n",
			stu[i].num,stu[i].name,stu[i].profession,
	   stu[i].china,stu[i].math,stu[i].english,stu[i].physical,stu[i].chemical);
    	}
	printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
		fclose(fp);
	}
	//按总分成绩排序 
	if(m==6)
	{
		for(i=0;i<n-1;i++)
	    {
			sum=0.0;
			sum=stu[i].china+stu[i].math+stu[i].english+stu[i].physical+stu[i].chemical;
			s[i]=sum;             // 定一个数组用于数组间信息操作//
	    }
	    for(i=0;i<n-1;i++)
		{
	        for(j=i+1;j<n;j++)
			if(s[j]>s[i])
			{
			t=s[j];s[j]=s[i];s[i]=t;      //按照总分大小进行排序//
		    temp=stu[j];stu[j]=stu[i];stu[i]=temp; 	//随之使其数组相应顺序随总分大小一起排序//
			}
		}
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
	    printf("   学号  姓名 专业  \t语文  \t数学  \t英语  \t物理  \t化学  \t总分\n");
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
	    for(i=0;i<n-1;i++)                             
	    {
			printf("  %s \t%s \t%s\t%.2f   \t%.2f   \t%.2f   \t%.2f   \t%.2f   \t\t%.2f\n",
			stu[i].num,stu[i].name,stu[i].profession,
			stu[i].china,stu[i].math,stu[i].english,stu[i].physical,stu[i].chemical,s[i]);
	    }
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
		fclose(fp);
  	}
  	//按平均分来排序 
	if(m==7)
	{
		for(i=0;i<n-1;i++)
	    {
			sum=0.0;
			sum=stu[i].china+stu[i].math+stu[i].english+stu[i].physical+stu[i].chemical;
			aver=sum/5; 
			ave[i]=aver;        
	    }
	    for(i=0;i<n-1;i++)
		{
	        for(j=i+1;j<n;j++)
			if(ave[j]>ave[i])
			{
			t=ave[j];ave[j]=ave[i];ave[i]=t;                  //按照平均分大小进行排序//
		    temp=stu[j];stu[j]=stu[i];stu[i]=temp; 		//随之使其数组相应顺序随平均分大小一起排序//
			}
		}
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
	    printf(" 学号   姓名  专业  \t语文  \t数学  \t英语  \t物理  \t化学  \t平均分\n");
		printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
	    for(i=0;i<n-1;i++)                             
	    {
			printf("  %s \t%s \t%s\t%.2f   \t%.2f   \t%.2f   \t%.2f   \t%.2f   \t\t%.2f\n",
			stu[i].num,stu[i].name,stu[i].profession,
			stu[i].china,stu[i].math,stu[i].english,stu[i].physical,stu[i].chemical,ave[i]);
	    }
	printf("^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^\n");
fclose(fp);
  	} 	
	system("pause");
}
5)数据修改函数
    通过多种方式(姓名,学号)找到学生的信息,进行修改该学生的数据。
代码如下:
void amend()
{
	FILE *fp;
	int i=0,n=0;
    char s[15];
	int m;
	system("cls");
	printf("\t\n请选择修改方式:\n");
    printf("\t┌──────┐\n");
    printf("\t│1------姓名 │\n");
    printf("\t│2------学号 │\n");
    printf("\t│3------返回 │\n");
    printf("\t└──────┘\n");
	printf("请输入你要修改的方式\n");
	scanf("%d",&m);
	while(m!=1&&m!=2&&m!=3)
	{
		printf("输入错误请重新修改\n");
	    scanf("%d",&m);
	}
	if((fp=fopen(filename,"r"))==NULL)                 //以2进制方式读取文件信息//
	{
		printf("cannot open the files\n");
		system("pause");
        return;
	}
	while(!feof(fp))
	{
		fread(&stu[i],sizeof(STU),1,fp);
		i++;n=n+1;
	}
	fclose(fp);
	system("cls");
	//按姓名找到学生进行修改信息 
    if(m==1)
	{
	  	char s[20];
	  	int i=0;
	  	printf("\t请输入想修改的姓名:");
	  	scanf("\t%s",s);
	  	while(strcmp(stu[i].name,s)!=0&&i<n) i++;                           //进行比较 找到所需要的信息
		if(i==n)
		{
			printf("\t成绩系统中没有此人!\n");
			return;
		}
	    else{
	    printf("学号:\n");
	    scanf("\t%s",stu[i].num);
	    printf("姓名:\n");
	    scanf("\t%s",stu[i].name);
	    printf("专业:\n");
	    scanf("\t%s",stu[i].profession);
	    printf("语文:\n");
	    scanf("\t%f",&stu[i].china);
	    printf("数学:\n");
	    scanf("\t%f",&stu[i].math);
	    printf("英语:\n");
	    scanf("\t%f",&stu[i].english);
	    printf("物理:\n");
	    scanf("\t%f",&stu[i].physical);
	    printf("化学:\n");
	    scanf("\t%f",&stu[i].chemical);
	    }
    }
    //按学号找到学生进行修改信息 
	if(m==2)
	{
		char s[20];
		int i=0;
		printf("请输入想修改的学号:");
		scanf("\t%s",s);
		while(strcmp(stu[i].num,s)!=0&&i<n)i++;
		if(i==n)
		{
		 	printf("\t成绩系统中没有此人!\n");
		 	return;
		}
		else{
	    printf("学号:\n");
	    scanf("\t%s",stu[i].num);
	    printf("姓名:\n");
	    scanf("\t%s",stu[i].name);
	    printf("专业:\n");
	    scanf("\t%s",stu[i].profession);
	    printf("语文:\n");
	    scanf("\t%f",&stu[i].china);
	    printf("数学:\n");
	    scanf("\t%f",&stu[i].math);
	    printf("英语:\n");
	    scanf("\t%f",&stu[i].english);
	    printf("物理:\n");
	    scanf("\t%f",&stu[i].physical);
	    printf("化学:\n");
	    scanf("\t%f",&stu[i].chemical);
		}
	}
	if((fp=fopen(filename,"w"))==NULL)   
	{
		printf("cannot open the files\n");
        return;
	}
	for(i=0;i<n-1;i++)
		if(fwrite(&stu[i],sizeof(STU),1,fp)!=1)
	    printf("file write error\n");
	fclose(fp);
	printf("信息已经修改成功\n");
	system("pause");
}
6)数据删除函数
通过输入该学生的学号对学生信息进行删除。
代码如下:
void delet()
{
    FILE *fp;
    char s[10];
	int i=0,n=0;
	if((fp=fopen(filename,"r"))==NULL)
	{
		printf("cannot open the files\n");
		system("pause");
        return;
	}
    while(!feof(fp))
	{
	  	fread(&stu[i],sizeof(STU),1,fp); 
	  	i++;n=n+1;
    }
    fclose(fp);
	if((fp=fopen(filename,"w"))==NULL) 
	{
		printf("cannot open the files\n");
		system("pause");
        return;
	}
	printf("学生学号:");
	scanf("%s",s);
    for(i=0;i<n-1;i++)
		if(!(strcmp(stu[i].num,s)==0))  //找到与其匹配的信息进行操作
//   如果条件符合就写入否者跳过这组数据此数据就是所需删除的
	  	fwrite(&stu[i],sizeof(STU),1,fp)!=1;  //以2进制方式将信息从内存中写入文件磁盘//
	fclose(fp);
	printf("数据删除成功");
	system("pause");
}

八、结语

通过本系统的设计与实现,我们不仅能够深入理解链表这一重要数据结构的应用,还能掌握文件存储、异常处理以及用户交互等关键技术。更重要的是,该系统能够为教育机构提供一个高效、便捷的学生成绩管理工具,促进教育信息化的进一步发展。

通过本文学习,对于C语言的基础语法可以说是掌握了,如果本文章对你有帮助的话,动动发财的小手点点赞和收藏❤★关注我要源码!!!!!!

  • 34
    点赞
  • 11
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值