版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、#i nclude<stdio.h>#in clude<stdlib.h>#i nclude<stri ng.h>int N1,N2;struct stude ntint nu m2;char name220;int n ele nu m50;int n ele n;struct stude nt * n ext;struct course/所选课程编号/所选课程学分和int numl;/ 课程编char name120;char major20;char type20;int credit;int period;char teacher20;int peo
2、ple;struct course *n ext;struct course * headl;struct stude nt * head2;void zha ng()struct course *p1,*p2;/选此门课程的人数/结构体指针/从键盘录入课程信息N1=0;p1=p2=(struct course *)malloc(sizeof(struct course);printf("课程编号t课程名称t主修t课程性质t学分t课时t教师 n");sea nf("%d%s%s%s%d%d%s",&p1-> nu m1,p1-> na
3、me1,p1->major,p1->type, &p1->credit,&p1->period,p1->teacher);p1->people=0; head 仁NULL;while(p1-> nu m1!=0)N1= N1+1;if(N1=1)head 1= p1;else p2->n ext=p1;p2=p1;p1=(struct course * )malloc(sizeof(struct course);sea nf("%d%s%s%s%d%d%s",&p1-> nu m1,p1->
4、 name1,p1->major,p1->type, &p1->credit,&p1->period,p1->teacher);p1->people=0;p2-> next=NULL;void zhang1()/从文件录入课程信息FILE * fp;char filepath20;struct course *p1,*p2;N仁0;printf("请输入您要读取的路径:");getchar();gets(filepath);if(fp=fope n(filepath,"r")=NULL)print
5、f(” 找不到 %s 文件!n",filepath);exit(O);p1=p2=(struct course*)malloc(sizeof(struct course);fsca nf(fp,"%d%s%s%s%d%d%s%d",&p1-> num1,p1-> name1,p1->major,p1-> type,&p1->credit,&p1->period,p1->teacher,&p1->people);while(!feof(fp)N1= N1+1;if(N1=1)head仁p
6、1;elsep2->n ext=p1;p2=p1;p1=(struct course * )malloc(sizeof(struct course);fsca nf(fp,"%d%s%s%s%d%d%s%d",&p1-> num1,p1-> name1,p1->major,p1-> type,&p1->credit,&p1->period,p1->teacher,&p1->people);p2-> next=NULL;void load()/录入课程信息函数int i;printf(
7、"ttt录入课程信息 n");printf("n1.从键盘录入");printf("n2.从文件录入");printf("n3.返回主菜单 n");printf("请选择 1-3:");sea nf("%d",&i);switch(i)case 1: zha ng();break;case 2:zha ng1();break;case 3:break;void insert(struct course *incourse)/ 增加课程信息struct course *
8、p0,*p1,*p2;p1=head1;pO=in course;if(head1=NULL)head1=p0;p0-> next=NULL;elsewhile(p0->num1>p1->num1) && (p1->next!=NULL)p2=p1;p1=p1- >n ext;if(p0->nu m1<=p1- >nu m1)if(head 1=p1)head 1=p0;elsep2->n ext=p0;pO->n ext=p1;elsep1- >n ext=pO;pO->n ext=NULL;N1=
9、 N1+1;void delc(i nt numl)/ 删除课程信息struct course *p1,*p2;if(head1=NULL)printf("n无法删除!n");goto end;p1=head1;while(num1!=p1->num1 && p1->next!=NULL)p2=p1;p1=p1- >n ext;if(nu m1=p1- >nu m1)if(p1=head1)head仁p1- >n ext;elsep2->n ext=p1- >n ext;printf("已删除 n"
10、;);N1= N1-1;elseprintf("没有此课程n");en d:;void managementc()/课程信息管理函数struct course * p1;int i,nu m1;printf("ttt课程信息管理 n");printf("1.添加课程 n");printf("2.删除课程 n");printf("3.返回 n");printf("请输入 1-3:n");sca nf("%d",&i);switch(i)case 1:
11、p1=(struct course *)malloc(sizeof(struct course);printf("课程编号t课程名称t主修t课程性质t学分t课时t教师 n");sca nf("%d%s%s%s%d%d%s",&p1-> num1,p1-> name1,p1->major,p1->type, &p1->credit,&p1->period,p1->teacher);p1->people=0;in sert(p1); break;case 2:printf("请
12、输入您要删除的课程编号:n");scan f("%d",&n um1);delc (nu m1);break;case 3:break;void putin(void)/从键盘录入学生信息int i;struct stude nt *p1,*p2;N2=0;p1=p2=(struct stude nt *)malloc(sizeof(struct stude nt); printf("学号t 姓名 n");sca nf("%d%s",&p1-> nu m2,p1-> name2);p1- >
13、n ele n=0;for(i=0;i<20;i+) p1->nelenumi=0;head2=NULL;while(p1-> nu m2!=0)N2=N2+1;if(N2=1)head2=p1;elsep2->n ext=p1;p2=p1;p1=(struct stude nt * )malloc(sizeof(struct stude nt);scan f("%d%s",&p1-> num2,p1-> name2);p1- >n ele n=0;for(i=0;i<20;i+) p1-> nele numi=
14、0;p2-> next=NULL;void putin2()/从文件录入学生信息int i=0;FILE * fp;char filepath20;struct stude nt *p1,*p2;N2=0;printf("请输入您要读取的路径:");getchar();gets(filepath);if(fp=fope n(filepath,"rt")=NULL)printf("找不到 %s 文件!n",filepath);exit(0);p1=p2=(struct stude nt*)malloc(sizeof(struct
15、stude nt);fread(p1,sizeof(struct stude nt),1,fp);head2=NULL;while(!feof(fp)i=0;N2=N2+1;if(N2=1)head2=p1;elsep2->n ext=p1;p2=p1;p1=(struct stude nt * )malloc(sizeof(struct stude nt); fread(p1,sizeof(struct stude nt),1,fp);p2-> next=NULL;void in put()/录入学生信息函数int i;printf("ttt 录入学生信息 n"
16、;);printf("n1.从键盘录入 n");printf("2.从文件录入n");printf("3.返回主菜单n");printf("请输入 1-3:n");sea nf("%d",&i);switch(i)ease 1:puti n();break;ease 2:put in 2();break;ease 3:break;/增加学生信息void in serts(struct stude nt * in eouse)struet stude nt *p0,*p1,*p2;p仁 h
17、ead2;p0=in eouse;if(head2=NULL)head2=p0; p0->n ext=NULL;elsewhile(p0->num2>p1->num2) && (p1->next!=NULL)p2=p1; p1=p1- >n ext;if(p0->num2 <= p1->num2)if(head2=p1) head2=p0;else p2->n ext=p0;p0->n ext=p1;elsep1- >n ext=p0;p0-> next=NULL;N2=N2+1;void dels(
18、i nt num2)/ 删除学生信息struct stude nt *p1,*p2;if(head2=NULL)prin tf("n 无法删除 n");goto end;p仁 head2;while(num2!=p1->num2 && p1->next!=NULL)p2=p1;p1=p1- >n ext;if(nu m2=p1- >nu m2)if(p1=head2)head2=p1- >n ext;elsep2->n ext=p1- >n ext;printf("已删除 n");N2=N2-1;
19、elseprintf("没有此学生编号n");en d:;void man ageme nts()/学生信息管理函数struct stude nt * p1;int i,nu m2;printf("ttt学生信息管理 n");printf("1.添加学生信息n");printf("2.删除学生信息n");printf("3.返回主菜单n");printf("请选择 1-3:n");sca nf("%d",&i);switch(i)case 1:p1
20、=(struct student *)malloc(sizeof(struct student);p1- >n ele n=0;p1-> nele num0=0;prin tf(" numtn amen");scan f("%d%s",&p1-> num2,p1-> name2);in serts(p1);break;case 2:printf("请输入您要删除的学生编号:n");scan f("%d",&n um2);dels( nu m2); break;case 3:b
21、reak;void elect()/ 学生选课struct stude nt * s;struct course * p;int a,i,b;printf("请输入您的学号:n");sca nf("%d",&a);s=head2;while(s-> nu m2)!=a&&s-> next!=NULL) s=s-> next;if(s->nu m2!=a)printf("您的信息不存在,请重新输入:n");goto end;if(s-> nele n)>10)printf(&q
22、uot;您的学分已满");goto end;printf("请输入您要选修的课程编号n");sca nf("%d",&b);for(i=0;(s->n ele nu mi)=0;i+);s->n ele nu mi=b;p=head1;while(p->nu m1)!=b)p=p->n ext;for(i=0;(s->n ele nu mi)!=0;i+);s->n ele nu mi=b;(p->people)+;(s->n ele n)=(s->n ele n)+(p->c
23、redit); (p->people)+;en d:;void back()/学生退课struct stude nt * p;struct course * p1;int b,i,j,a;printf("请输入您的学号:n");sca nf("%d",&a);p=head2;while(p-> num2!=a&&p!=NULL) p=p-> next; if(p=NULL)printf("您的信息不存在:n");elseprintf("请输入您要退选的课程:n"); sca
24、n f("%d",&b);p1=head1;while(p1- >nu m1!=b) p1=p1- >n ext; for(i=0;p->n ele nu mi!=b;i+);for(j=i;p->n ele nu mj!=O;j+)p->n ele nu mj=p->n ele nu mj+1;p->n ele num -j=0;(p->n ele n)=(p->n ele n)-(p1->credit); (p1->people)-;prin tf("succeed!n");v
25、oid elective()/学生选课信息管理int i;printf("ttt学生选课信息管理n");printf("1.选课n");printf("2.退课n");printf("3.返回主菜单n");printf("请输入 1-3:n");sea nf("%d",&i);switch(i)ease 1:elect();break;ease 2:baek();break;ease 3:break;void liste()/浏览课程信息struet eourse *
26、 p;p=head1;课时printf("课程编号课程名称主修课程性质学分教师选课人数n");while(p!=NULL)prin tf("%6d%13s%13s%10s%7d%7d%12s%5dn",p-> num1,p->n ame1,p ->major,p->type,p->credit,p->period,p->teacher,p->people);p=p->n ext;void lists()/浏览学生信息struct stude nt * p;int a;所选课程学分n");p=
27、head2;printf("学生编号 学生姓名所选课程编号while(p!=NULL)prin tf("%6d%13s",p-> num2,p-> name2);prin tf("%6d",p-> nele n);for(a=0;p->n ele numa!=O&&a<14;a+)prin tf("%d",p-> nele nu ma);prin tf("n");p=p->n ext;void intoc()/存储课程信息FILE * fp;str
28、uct course * p;char filepath30;printf("输入路径:");getchar();gets(filepath);if(fp=fope n(filepath,"w")=NULL)无法储存!");exit(O);p=head1;while(p!=NULL)fprin tf(fp,"%d%s%s%s%d%d%s%dn",p-> num1,p-> name1,p->major,p- >type,p->credit,p->period,p->teacher,p-
29、>people);p=p->n ext;fclose(fp);printf("已储存入 %s 文件!n",filepath);void intos()/存储学生信息FILE * fp;struct stude nt * p;char filepath30;printf("请输入路径:");getchar();gets(filepath);if(fp=fope n(filepath,"wt")=NULL)printf("n无法储存!");exit(0);p=head2;while(p!=NULL)fwri
30、te(p,sizeof(struct stude nt),1,fp);p=p->n ext;fclose(fp);printf("已储存入 %s 文件!n",filepath);void into()/信息存储函数int i;printf("ttt信息存储 n");printf("1.课程信息存储n");printf("2.学生信息存储tn");printf("3.返回主菜单n");printf("请输入 1-3n");sea nf("%d",&am
31、p;i);switch(i)ease(1):i ntoc();break;case(2):i ntos();break; ease(3):break;/信息存储浏览函数void store()int i;printf("tt信息存储和浏览n");printf("1.课程信息浏览n");printf("2.学生信息浏览n");printf("3.信息存储 n");printf("4.返回主菜单n");printf("请输入 1-4:n");sca nf("%d&quo
32、t;,&i);switch(i)case(1):listc();break;case(2):lists();break;case(3):i nto();break;case(4):break;void search1()/按学生编号查找学生信息int a,b;struct stude nt * p;printf("请输入学生编号");sca nf("%d",&a);p=head2;printf("学号学生姓名所选课程编号所选课程学分n");while(p!=NULL)if(p->nu m2=a)printf(&q
33、uot;%6d%13s ",p->num2,p->name2);for(b=0;p-> nele numb!=0&&b<14;b+)prin tf("%d",p-> nele nu mb);prin tf("%10dn",p-> nele n);p=p->n ext;void search2()/按学生姓名查找学生信息int b;char n ame20;struct stude nt * p;printf("请输入要查找的学生姓名:");sca nf("%
34、s", name);p=head2;printf("学号学生姓名所选课程编号所选课程学分n");while(p!=NULL)if(strcmp( name,p->n ame2)=0)printf("%6d%13s ",p->num2,p->name2); for(b=0;p-> nele numb!=0&&b<14;b+) prin tf("%d",p-> nele nu mb);prin tf("%10dn",p-> nele n);p=p->n ext;void search()int i;printf("ttt学生信息查找");printf("n1. 按学号查找");printf("n2.按姓名查找");printf("n3.返回主菜单");prin tf("n 请输入 1-3:");sca nf("%d",&i);switch(i)case 1:search1();break;case 2:search2();break;
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 人教版八年级物理下册《第七章力》单元检测卷及答案
- 开发具有抗虫特性的转基因作物品种
- 新高考走班制选课排课解决方案
- 高一化学达标训练:第四单元太阳能、生物质能和氢能的利用
- 2024届江苏省淮阴区高三二诊模拟考试数学试卷含解析
- 2024高中物理第四章牛顿运动定律3牛顿第二定律课后作业含解析新人教版必修1
- 2024高中语文第一课走进汉语的世界第2节古今言殊-汉语的昨天和今天训练含解析新人教版选修语言文字应用
- 2024高考化学一轮复习第1章认识化学科学章末化学素材与命题架构学案鲁科版
- 2024高考地理一轮复习专练64区域能源矿产资源的综合开发利用含解析新人教版
- 人教版四年级上册数学20套试卷(可打印)
- 关于水浒传的题目单选题100道及答案解析
- 机电设备安装施工及验收规范
- 冠心病课件完整版本
- 磷化工产业链副产物资源农业全量利用途径分析
- 浙江省舟山市定海区2023-2024学年七年级上学期期末科学试题
- 仓库安全培训考试题及答案
- 第六单元 中华民族的抗日战争 教学设计 2024-2025学年统编版八年级历史上册
- 初中古诗文言文背诵内容
- 附件2:慢病管理中心评审实施细则2024年修订版
- 《ISO56001-2024创新管理体系 - 要求》之4:“4组织环境-确定创新管理体系的范围”解读和应用指导材料(雷泽佳编制-2024)
- 近三年投标没有发生过重大质量安全事故的书面声明范文
评论
0/150
提交评论