实现对两个文件数据进行合并,生成新文件3.txt

2019-03-29 17:38

要用的请复制,要转载的请注明,要问的免了 题目如下

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 fileread(char *adress) //读取成绩文件 {

FILE * fp;

if((fp=fopen(adress,\打开文件 {

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,\glish); //将文件的数据输入到链表中 n=1;

}

if(fclose(fp)) //关闭文件 {

printf(\文件关闭失败\exit(0); }

return file; }

void FilePrint(gradelist file) //将成绩文件打印到屏幕上 {

student *p=file;

printf(\打印标题 while(p->next!=NULL) {

printf(\nglish); //循环打印 p=p->next; } }

void merger() //合并文件 {

char * address1=\gradelist file1=fileread(address1),file2=fileread(address2); FILE *fp;

if((fp=fopen(\先新建一个3.txt,然后将1.txt和2.txt的内容输入到里面 {

printf(\合并成绩文档失败,原因:建立文档出错\exit(0); }

student *p1=file1,*p2=file2;

fprintf(fp,\先输入标题 while(p1->next!=NULL) {

fprintf(fp,\ath,p1->english); //输入1.txt p1=p1->next; }

while(p2->next!=NULL) {

fprintf(fp,\ath,p2->english); //输入2.txt

p2=p2->next; }

if(fclose(fp)) {

printf(\文件关闭失败\exit(0); } }

void extract() //抽取补考的成绩记录 {

char * address4=\FILE *fp;

if((fp=fopen(\新建文件4.txt {

printf(\抽取补考学生成绩记录建立新文件失败\exit(0); }

gradelist file3=fileread(address3); student *p=file3;

fprintf(fp,\先输入标题 while(p->next!=NULL) {

if((p->chinese)<60||(p->math)<60||(p->english)<60) //补考条件 {

fprintf(fp,\p->english); }

p=p->next; }

if(fclose(fp)) {

printf(\文件关闭失败\exit(0); } }

void sort(int i) {

char * address3=\

gradelist file3=fileread(address3); //先将3.txt读入链表 student *p=file3;

if(remove(\由于排序后的内容也要保存到3.txt,故删除3.txt {

printf(\删除文件出错\exit(0); }

int n=0; //学生个数 FILE *fp;

if((fp=fopen(\新建一个空的3.txt {

printf(\新建文件出错\exit(0); }

fprintf(fp,\标题先输入 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]; //只初始化了100了空间,学生人数超过100就不能了,懒得动态分配了

}grade_list; //待排序成绩表 grade_list L; p=file3;

for(int t=1;t<=n;t++,p=p->next) //将链表的内容复制到结构数组里 {

strcpy(L.r[t].name,p->name); L.r[t].number=p->number; L.r[t].chinese=p->chinese; L.r[t].math=p->math;

L.r[t].english=p->english;

L.r[t].totalgrade=p->chinese+p->math+p->english; }

if(i==1) //直接插入排序,具体思想参考《数据结构》,严蔚敏主编 {

for(int k=2;k<=n;++k)


实现对两个文件数据进行合并,生成新文件3.txt.doc 将本文的Word文档下载到电脑 下载失败或者文档不完整,请联系客服人员解决!

下一篇:形容人的形容词

相关阅读
本类排行
× 注册会员免费下载(下载后可以自由复制和排版)

马上注册会员

注:下载文档有可能“只有目录或者内容不全”等情况,请下载之前注意辨别,如果您已付费且无法下载或内容有问题,请联系我们协助你处理。
微信: QQ: