实现对两个文件数据进行合并-生成新文件3.txt_第1页
实现对两个文件数据进行合并-生成新文件3.txt_第2页
实现对两个文件数据进行合并-生成新文件3.txt_第3页
实现对两个文件数据进行合并-生成新文件3.txt_第4页
实现对两个文件数据进行合并-生成新文件3.txt_第5页
已阅读5页,还剩2页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、要用的请复制,要转载的请注明,要问的免了 题目如下 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)实现对两个文件数

2、据进行合并 , 生成新文件 3.txt 2)抽取出三科成绩中有补考的学生并保存在一个新文件 4.txt 3)合并后的文件 3.txt 中的数据按总分降序排序 ( 至少采用两种排序方法实现 ) 4)输入一个学生姓名后 , 能查找到此学生的信息并输出结果 (至少采用两种查找 方法实现 ) 5)要求使用结构体 , 链或数组等实现上述要求 6)采用多种方法且算法正确者 ,可适当加分 . 源代码如下 #include #include #include char top50; / 成绩文件顶部的标题用 top 保存 typedef struct student / 单个学生成绩的记录 char name

3、10; / 姓名 int number; / 学号 int chinese; /语文 int math; / 数学 int english; / 英语 struct student *next; student,*gradelist; gradelist (char *adress) / 读取成绩文件 FILE * fp; if(fp=fopen(adress,r)=NULL) / 打开文件 printf( 文件打开出错 ); exit(0); gradelist file=(student *)malloc(sizeof(student); / 申请空间 file-next=NULL; st

4、udent * 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); ret

5、urn file; void (gradelist file) / 将成绩文件打印到屏幕上 student *p=file; printf(%sn,top); / 打印标题 while(p-next!=NULL) printf(%6s %2d %d %d %dn,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),(address

6、2); FILE *fp; if(fp=fopen(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 %dn,p1-name,p1-number,p1-chinese,p1-m ath,p1-english); / 输入 1.txt p1=p1-nex

7、t; while(p2-next!=NULL) fprintf(fp,%6s %2d %d %d %dn,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=fopen(4.txt,w+)=NULL) / 新建文件 4.txt printf( 抽取补考学生成绩

8、记录建立新文件失败 ); 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.tx

9、t 读入链表 student *p=file3; if(remove(3.txt) / 由于排序后的内容也要保存到 3.txt ,故删除 3.txt printf( 删除文件出错 ); exit(0); int n=0; / 学生个数 FILE *fp; if(fp=fopen(3.txt,w+)=NULL) / 新建一个空的 3.txt printf( 新建文件出错 ); exit(0); fprintf(fp,%s,top); /标题先输入 while(p-next!=NULL) n+; p=p-next; typedef struct / 链表不容易操作,故而新建一个结构数组 int t

10、otalgrade; char name10; int number; int chinese; int math; int english; gradenote; / 成绩记录 typedef struct gradenote r100; / 只初始化了 100了空间,学生人数超过 100 就不能了,懒 得动态分配了 grade_list; / 待排序成绩表 grade_list L; p=file3; for(int t=1;tnext) / 将链表的内容复制到结构数组里 strcpy(L.,p-name); L.rt.number=p-number; L.rt.chines

11、e=p-chinese; L.rt.math=p-math; L.rt.english=p-english; L.rt.totalgrade=p-chinese+p-math+p-english; if(i=1) / 直接插入排序,具体思想参考数据结构,严蔚敏主编 for(int k=2;k=n;+k) if(L.rk.totalgradeL.rk-1.totalgrade) L.r0=L.rk; L.rk=L.rk-1; for(int j=k-2;L.r0.totalgradeL.rj.totalgrade;-j) L.rj+1=L.rj; L.rj+1=L.r0; if(i=2) / 折

12、半插入排序,参考同上 int m; for(int k=2;k=n;+k) L.r0=L.rk; int low=1,high=k-1; while(low=high) m=(low+high)/2; if(L.r0.totalgrade=high+1;-j) L.rj+1=L.rj; L.rhigh+1=L.r0; for(int q=n;q=1;q-) /将排序好的内容输入到 3.txt fprintf(fp,%6s %2d %d %d %dn,L.,L.rq.number,L.rq.chin ese,L.rq.math,L.rq.english); if(fclose(fp

13、) printf( 文件关闭失败 ); exit(0); void search(char *name) / 按姓名查找 gradelist (3.txt); student * p=file; while(p-next!=NULL) if(strcmp(name,p-name)=0) printf(%6s %2d %d %d %dn,p-name,p-number,p-chinese,p-math,p-e nglish); return; p=p-next; printf( 查无此人 , 请确定名字输入正确 n); exit(0); void main(void) / 本代码由武汉工业学院计

14、科 09 级,百度 ID 轻盈流飞雪 所 编,转载注明,完成作业请删除此句,不懂勿问,哥很忙 int chioce; gradelist (1.txt),(2.txt); printf( 现有成绩记录文件 1n); printf( f* *n); (file1); printf( f* *n); printf( 现有成绩记录文件 2n); printf( f* *n); (file2); printf( f* *n); printf( 第一步,合并成绩记录文件 n); merger(); printf( 合并成功 n); system(PAUSE); printf( 现有合并后的成绩记录文件

15、3n); printf( f* *n); gradelist (3.txt); (file3); printf( f* *n); printf( 第二步,抽取补考成绩记录 n); extract(); system(PAUSE); printf( 现有补考成绩记录文件 4n); printf( f* *n); gradelist (4.txt); (file4); printf( f* *n); printf( 第三步,对文件 3 进行排序 n); printf( 请输入排序方式 (1/2)n1: 直接插入排序 n2: 折半插入排序 n); scanf(%d, if(chioce=1) sort(1); else if(chioce=2) sort(2); el

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论