实现对两个文件数据进行合并-生成新文件txt
要用的请复制,要转载的请注明,要问的免了 题目如下 25.25.学生成绩管理系统学生成绩管理系统 现有学生成绩信息文件 1.txt,内容如下 姓名 学号 语文 数学 英语 张明明 01 67 78 82 李成友 02 78 91 88 张辉灿 03 68 82 56 王露 04 56 45 77 陈东明 05 67 38 47 学生成绩信息文件 2.txt,内容如下: 姓名 学号 语文 数学 英语 陈果 31 57 68 82 李华明 32 88 90 68 张明东 33 48 42 56 李明国 34 50 45 87 陈道亮 35 47 58 77 试编写一管理系统,要求如下: 1)实现对两个文件数据进行合并,生成新文件 3.txt 2)抽取出三科成绩中有补考的学生并保存在一个新文件 4.txt 3)合并后的文件 3.txt 中的数据按总分降序排序(至少采用两种排序方法实现) 4)输入一个学生姓名后,能查找到此学生的信息并输出结果(至少采用两种查找 方法实现) 5)要求使用结构体,链或数组等实现上述要求. 6)采用多种方法且算法正确者,可适当加分. 源代码如下 #include #include #include char top[50]; //成绩文件顶部的标题用 top 保存 typedef struct student //单个学生成绩的记录 { char name[10]; //姓名 int number; //学号 int chinese; //语文 int math; //数学 int english; //英语 struct student *next; }student,*gradelist; gradelist (char *adress) //读取成绩文件 { FILE * fp; if((fp=(adress,“r“))==NULL) //打开文件 { printf(“文件打开出错“); exit(0); } gradelist file=(student *)malloc(sizeof(student)); //申请空间 file-next=NULL; student * p=file; //操作指针 int n=0; //循环标记,具体作用是在第一次循环时方便处理标题 while(!feof(fp)) { if(n==0) { fgets(top,50,fp); //处理标题,并且文件指针移到第二行 } if(n==1) //申请空间 { (p-next)=(student *)malloc(sizeof(student)); p=p-next; p-next=NULL; } fscanf(fp,“%s%d%d%d%d“,p-name, //将文件的数据输入到链表中 n=1; } if(fclose(fp)) //关闭文件 { printf(“文件关闭失败“); exit(0); } return file; } void (gradelist file) //将成绩文件打印到屏幕上 { student *p=file; printf(“%s\n“,top); //打印标题 while(p-next!=NULL) { printf(“%6s %2d %d %d %d\n“,p-name,p-number,p-chinese,p-math,p-e nglish); //循环打印 p=p-next; } } void merger() //合并文件 { char * address1=“1.txt“,*address2=“2.txt“,*address3=“3.txt“; gradelist (address1),(address2); FILE *fp; if((fp=(“3.txt“,“w+“))==NULL) //先新建一个 3.txt,然后将 1.txt 和 2.txt 的内容输入到里面 { printf(“合并成绩文档失败,原因:建立文档出错“); exit(0); } student *p1=file1,*p2=file2; fprintf(fp,“%s“,top); //先输入标题 while(p1-next!=NULL) { fprintf(fp,“%6s %2d %d %d %d\n“,p1-name,p1-number,p1-chinese,p1-m ath,p1-english); //输入 1.txt p1=p1-next; } while(p2-next!=NULL) { fprintf(fp,“%6s %2d %d %d %d\n“,p2-name,p2-number,p2-chinese,p2-m ath,p2-english); //输入 2.txt p2=p2-next; } if(fclose(fp)) { printf(“文件关闭失败“); exit(0); } } void extract() //抽取补考的成绩记录 { char * address4=“4.txt“,*address3=“3.txt“; FILE *fp; if((fp=(“4.txt“,“w+“))==NULL) //新建文件 4.txt { printf(“抽取补考学生成绩记录建立新文件失败“); exit(0); } gradelist (address3); student *p=file3; fprintf(fp,“%s“,top); //先输入标题 while(p-next!=NULL) { if((p-chinese)math)english)name,p-number,p-chinese,p-math, p-english); } p=p-next; } if(fclose(fp)) { printf(“文件关闭失败“); exit(0); } } void sort(int i) { char * address3=“3.txt“; gradelist (address3); //先将 3.txt 读入链表 student *p=file3; if(remove(“3.txt“)) //由于排序后的内容也要保存到 3.txt,故删除 3.txt { printf(“删除文件出错“); exit(0); } int n=0; //学生个数 FILE *fp; if((fp=(“3.txt“,“w+“))==NULL) //新建一个空的 3.txt { printf(“新建文件出错“); exit(0); } fprintf(fp,“%s“,top); //标题先输入 while(p-next!=NULL) { n++; p=p-next; } typedef struct //链表不容易操作,故而新建一个结构数组 { int totalgrade; char name[10]; int number; int chinese; int math; int english; }gradenote; //成绩记录 typedef struct { gradenote r[100]; //只初始化了 10