ImageVerifierCode 换一换
格式:DOCX , 页数:30 ,大小:205.52KB ,
资源ID:3590467      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-3590467.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(学生信息管理系统课程设计报告实验报告.docx)为本站会员(b****1)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

学生信息管理系统课程设计报告实验报告.docx

1、学生信息管理系统课程设计报告实验报告*大学 课 程 设 计 报 告 课程名称 高级语言程序设计 设计题目 学生信息管理系统 专 业 计算机科学与技术 班 级 学 号 姓 名 完成日期 课 程 设 计 任 务 书设计题目: 学生信息管理系统设计 设计内容与要求:内容:对学生信息进行管理,学生信息包括学号、姓名、性别、年龄、学历、学号、住址、电话等(学号不重复)。要求:(1) 系统以菜单方式工作(2) 学生信息录入功能(学生信息用文件保存) 。(3) 输出学生信息、浏览学生信息功能。(4) 查询和排序功能:(至少一种查询方式) ,如按学号查询、按学历查询等。(5) 学生信息删除、修改功能(任选项)

2、。 指导教师:_ 年 月 日课 程 设 计 评 语 成绩: 指导教师:_ 年 月 日【问题描述】 学生信息管理软件设计。对学生信息进行管理,学生信息包括:学号,姓名,年龄,性别,出生年月,地址,电话,E-mail等。试设计一个学生信息管理软件。【基本要求】一、输入的形式和输入值的范围形式:用scanf输入学生的学号,姓名,年龄,性别,出生年月,地址,电话,E-mail。输入一个学生信息一个回车。用输入的学号p1-num来控制输入,当输入的学号为0时,用break跳出循环。即if(p1-num=0)break。输入值的范围:学号、年龄为整型 long num; int age; 姓名为字符串型1

3、5个字节char name15; 性别为字符串型,10个字节char sex10; 出生为字符串型,20个字节char chushen20; 地址为字符串型,30个字节char dizhi30;邮箱为字符串型,输入11位数字char email11。二、输出的形式输出是以表格的形式输出,即表格的每一行都能显示第一个学生的信息,第二行是显示第二个学生的信息。三、程序所能达到的功能对学生信息进行管理,学生信息包括职学号,姓名,年龄,性别,出生年月,地址,电话,E-mail。(1)系统以菜单方式工作(2)学生信息录入功能。(3)输出学生信息、浏览学生信息功能。(4)查询和排序功能:(至少一种查询方式

4、),如按学号查询、按姓名查询等。(5)学生信息删除、修改功能(任选项)。(6)添加学生信息。【测试数据】输入:设输入四个学生信息,以最后一个学生的学号为0来结束输入,学号是整型。预期的输出结果:预期的输出结果请参见程序后的运行结果。【数据结构】排序记录的数据元素表采用一维数组存储结构,每个元素包含8个关键字段,其类型描述为:#include #include /分配size字节的存储区#include /包含字符串处理函数的头文件,可以直接调用现有的字符串处理的一系列函数#define len sizeof(struct student) /宏定义求字节运算符#include /清屏功能str

5、uct student /声明一个结构体类型struct student long num; /定义学号为long型数据 char name15; /定义姓名 int age; /定义年龄 char sex3; /定义性别 char chushen10; /定义出生 char dizhi20; /定义出生地址 char phone11; /定义电话 char email20; /定义邮箱 struct student *next; /next是指针变量,指向结构体变量【算法思想】利用一维结构体存放所有学生的信息,输入后,在输出时要对学生按学号的高低排序,然后可以执行按学号查询学生信息,输入学号

6、,删除学生信息,输入学号可以找出该学生信息,然后选择修改学生信息,如果来了新学生,还可以添加学生信息。【总体设计】输入一个学生学号,来删除该学生信息输入学号,修改的学生信息显示主菜单输入函数学生排序输出学生信息删除学生信息修改学生信息添加学生信息用键盘输入学生信息按学生学号高低排序在原有的学生上添加学生信息以表格的形式输出学生信息主菜单包括:输入函数、学号排序、浏览函数、删除函数、修改函数、添加函数。 图1-1学生管理总体设计【模块划分】一、主函数:main()显示系统工作菜单,显示该系统的所有功能。告诉使用者所有将会调用的被调函数,再运用选择函数switch即可根据使用者所输入的学号进入对应

7、的功能程序。并且对菜单做了一个循环,进行完一个选择后,按回车键可进行清屏功能,把屏幕上除了主菜单以外都清空,然后可以继续选择那些可以使用的功能,这样可以方便使用者使用,并且每一步都很清晰。以8退出系统。 二、输入函数:struct student *creat()在该程序的前面已经定义了一个结构体struct student用来储存学生的所有信息,(学号、年龄、姓名、性别、出生日期、地址、电话、邮箱)。定义p1和p2,struct student *p1,*p2;p1,p2是指向struct student类型数据的指针变量。定义一个n=0,n是输入的个数,主要作用是:如果输入一个学生信息,首

8、地址指向p1,head=p1;否则p2的下一个地址指向p1,p2指向p1. p2-next=p1;p2=p1;学号控制循环。三、排序函数:void paixu(struct student *head)用一个for语句做循环,不是NULL的话,指针指向下一个,按学生学号高低排序。整形直接交换,字符型用strcpy交换,类型相当于两个数据之间的交换。四、输出函数:void printlist(struct student *head) 在主函数里边用while控制循环,输出学生信息,然后指针指向下一个。5、查询函数:void findList_num(struct student *head)

9、和void findList_num(struct student *head)输入一个学号或姓名,做一个for循环,即指针pt指向第一个地址,再定义一个指针p1,让它等于pt,他是紧跟着pt后面的一个指针,让p1-next不等于NULL,pt指向下一个地址。这样就能修改最后一个学生信息了。如果要查询的学生的学号在学生里,就输出该学生信息,否则,就输出查询的学生信息不存在。六、删除函数:int shanchu(struct student *head)输入一个学号,先找到这个学生的信息。如果输入的学号在学生信息中,就进行以下循环:如果输入的是第一个学生的话,就head等于第二个学生信息;如果输

10、入的学生信息是最后一个,就让倒数第二个等于NULL;否则的话,就让下一个学生信息覆盖前一个。如果输入的学号不在学生信息中,输出“此学生信息不存在”。七、修改函数:struct student *delList(struct student *head,long del_num)输入要修改的学号,找到该学生并且输出该学生的信息。然后屏幕上会出现学生信息的所有项目,用switch进行选择修改的项目。选择后输入新的学生信息,用它来覆盖原来的学生信息。八、添加函数:void insert(struct student *head) 用一个while语句while(p2-next!=NULL)控制循环,

11、p2的指针指向下一个地址,即p2=p2-next;这是找到最后一个地址,然后开辟动态存储区,p1=(struct student *)malloc(len);输入要添加的学号,用学号为0来终止循环,如果不为0,就继续输入学生信息。【源程序】#include #include /分配size字节的存储区#include /包含字符串处理函数的头文件,可以直接调用现有的字符串处理的一系列函数#define len sizeof(struct student) /求字节运算符#include /清屏功能FILE *fp;struct student /声明一个结构体类型struct studenti

12、nt num; /学号为整型 char name20; /姓名为字符串 char genter10; /性别为字符串 int age; /年龄为整型 char xueli20; /学历为字符串 int gongzi; /学号为整型 char address30; /地址为字符串 char phone11; /电话为字符串 struct student *next; /next是指针变量,指向结构体变量;void menu() printf(=学生信息管理系统=nn); printf( 1、录入学生信息n); printf( 2、浏览学生信息n); printf( 3、查询学生信息n); pri

13、ntf( 4、删除学生信息n); printf( 5、插入学生信息n); printf( 6、修改学生信息n); printf( 7、排序学生信息n); printf( 8、退出管理系统n); printf(=n);struct student *creat() /录入学生信息 int n; struct student *head; struct student *p1,*p2; n=0; p1=p2=(struct student *) malloc(len); scanf(%dt%dt%st%st%st%st%st%s,&p1-num,&p1-age,p1-name,p1-sex,p1-

14、chushen,p1-dizhi,p1-phone,p1-email); head=NULL; while(p1-num!=0) n=n+1; if(n=1) head=p1; else p2-next=p1; p2=p1; p1=(struct student *)malloc(len); scanf(%dt%dt%st%st%st%st%st%s,&p1-num,&p1-age,p1-name,p1-sex,p1-chushen,p1-dizhi,p1-phone,p1-email); p2-next=NULL; return(head); void insert(struct stude

15、nt *head) /插入学生信息 int search_num; struct student *p,*q,*s; p=head; printf(在哪个学生前插入 请输入学号:n); scanf(%d,&search_num); while(p!=NULL)&(p-num!=search_num) q=p; p=p-next; s=(struct student *)malloc(len); q-next=s; system(cls); printf(请输入学生信息:n); printf(学号t年龄t姓名t性别t出生t地址t电话te-mailn); scanf(%dt%dt%st%st%st

16、%st%st%s,&s-num,&s-age,s-name,s-sex,s-chushen,s-dizhi,s-phone,s-email); s-next=p;void printList(struct student *head) /浏览全部学生信息 struct student *p; p=head; if(head=NULL) printf(没有学生信息!n); else do fread(p,len,1,fp); printf(%dt%dt%st%st%st%st%st%sn,p-num,p-age,p-name,p-sex,p-chushen,p-dizhi,p-phone,p-e

17、mail); p=p-next; while(p!=NULL); void findList_num(struct student *head,long search_num) /按学号查找 struct student *p; p=head; while(p!=NULL)&(p-num!=search_num) p=p-next; if(p!=NULL) printf(%dt%dt%st%st%st%st%st%sn,p-num,p-age,p-name,p-sex,p-chushen,p-dizhi,p-phone,p-email); else printf(没有该学生信息!n);void

18、 findList_name(struct student *head,char *search_name) /按姓名查找 struct student *p; int cmp1=0,cmp=0; p=head; while(p!=NULL) if(strcmp(p-name,search_name)!=0) p=p-next; cmp+; else printf(%dt%dt%st%st%st%st%st%sn,p-num,p-age,p-name,p-sex,p-chushen,p-dizhi,p-phone,p-email); p=p-next; cmp1=1; if(cmp!=0&cm

19、p1=0) printf(没有该学生信息!n); void xiugai(struct student *p1,long xiu_num) /修改学生信息 struct student *p2; p2=p1; while(p2!=NULL)&(p2-num!=xiu_num) p2=p2-next; if(p2!=NULL) scanf(%dt%dt%st%st%st%st%st%s,&p2-num,&p2-age,p2-name,p2-sex,p2-chushen,p2-dizhi,p2-phone,p2-email); else printf(没有该学生信息!n); struct stud

20、ent *delList(struct student *head,long del_num) / 删除学生信息 struct student *p,*q; p=head; q=head; while(p &(p-num != del_num) q=p; p=p-next; if(p=NULL) printf(无此学号!n); else if(p = head) head = p-next; free(p); else q-next = p-next; free(p); return head;void paixu(struct student *head) /按学号排序 struct stu

21、dent *p,*f,*t; char ch100; int i; t=f=p=head; for(p=head;p-next!=NULL;p=p-next) for(t=head,f=t-next;t-next!=NULL;t=t-next,f=f-next) if(t-numf-num0) i=t-num; t-num=f-num; f-num=i; i=t-age; t-age=f-age; f-age=i; strcpy(ch,t-name); strcpy(t-name,f-name); strcpy(f-name,ch); strcpy(ch,t-sex); strcpy(t-se

22、x,f-sex); strcpy(f-sex,ch); strcpy(ch,t-chushen); strcpy(t-chushen,f-chushen); strcpy(f-chushen,ch); strcpy(ch,t-dizhi); strcpy(t-dizhi,f-dizhi); strcpy(f-dizhi,ch); strcpy(ch,t-phone); strcpy(t-phone,f-phone); strcpy(f-phone,ch); strcpy(ch,t-email); strcpy(t-email,f-email); strcpy(f-email,ch); / re

23、turn head;void save(struct student *head) /保存为磁盘文件 struct student *p; if(fp=fopen(keshe,w)=NULL) /打开一个文件 printf(cannot open this filen); exit(0); p=head; while(p!=NULL) fprintf(fp,%dn,p-num); fprintf(fp,%dn,p-age); fprintf(fp,%sn,p-name); fprintf(fp,%sn,p-sex); fprintf(fp,%sn,p-chushen); fprintf(fp,

24、%sn,p-dizhi); fprintf(fp,%sn,p-phone); fprintf(fp,%sn,p-email); p=p-next; fclose(fp);struct student *read() /从磁盘读取文件 struct student *head=NULL; struct student *p=NULL; struct student *t=NULL; int a;/ fp=fopen(keshe,r); if(fp=fopen(keshe,r)=NULL) /打开一个文件 printf(cannot open this filen); exit(0); while

25、(1) t=(struct student *)malloc(len); a=fscanf(fp,%dt%dt%st%st%st%st%st%s,&t-num,&t-age,t-name,t-sex,t-chushen,t-dizhi,t-phone,t-email); if(a=0|a=-1) return head; t-next=NULL; if(p=NULL) p=t; head=t; else p-next=t; p=p-next; p-next=NULL; fclose(fp);void main() /主函数 int code=0; struct student *pt = NU

26、LL; for(code=1;code+) /控制循环 menu(); /调用菜单函数 printf(请输入序号:n); /提示输入序号 scanf(%d,&code); system(cls); /清屏(下边也是这样的功能) switch(code) /选择序号进行功能选择 case 1: system(cls); printf(=输入学生信息 =n); printf(-n); printf(学号t年龄t姓名t性别t出生t地址t电话te-mailn); pt=creat(); /调用输入函数 save(pt); /将数据存储到磁盘中 system(cls); printf(=输入学生信息 =n); printf(-n); printf(*成功输入学生信息*!nn); printf(按回车键返回主菜单n); getchar(); getchar(); /按回车键返回 system(cls);break;case 2: system(

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2