




已阅读5页,还剩26页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
xxxxxxx高级语言课程设计实验报告系 别:xxxxxxxx专业班级:xxxxxxxxx学 号:xxxxxxxxxxx班内序号:xx姓 名:xxxx指导老师:xxxxxxxxx 实验课题:学生通讯信息管理系统实验时间:2008.6.102008.6.202008年6月17日一、实验目的1. 熟悉c语言的编译,链接和运行过程;2. 掌握c语言的数据类型,熟悉整型、实型、字符型变量的定义方式及如何给它们赋值,掌握不同的类型数据之间的赋值规律,赋值使用方法;3. 掌握if语句及switch语句的运用方法及嵌套应用方法;4. 掌握实现循环结构的三种语句while、 do-while.、for 的使用;5. 掌握c语言函数的定义,声名及调用方法和调用过程;6. 掌握c语言主函数和被调用函数之间的参数传递方式,学会函数的嵌套调用和递归调用的过程和方法;7. 掌握数组的定义,赋值引用及输入输出方法,并正确用字符数组储存字符串,学会字符串的使用;8. 掌握结构体类型变量的定义和使用;9. 掌握指针变量和指向指针的指针变量的定义及使用,进一步了解指向结构体数组的指针变量的概念及使用方法;10. 掌握链表的概念及链表的操作,并理解链表与数组的不同点及优缺点;11. 掌握文件和文件指针的定义及文件建立,打开,关闭,读写等的操作方法12. 能够采用模块化思想调试程序;二实验内容1. 编写程序并进行调试运行;2. 输入学生通讯信息并保存于文件,每个学生包含信息如:序号,姓名,省份,电话,生日,邮编,大学,班级,qq号信息;3. 对已存入的学生信息进行更新操作,包括添加一个学生信息、删除某个学生信息和修改某个学生信息;4. 通过输入姓名,学号的方式查询学生信息;5. 可以通过省份,生日来统计通讯信息;6. 最后输出学生信息,供需要时打印。 一、 需求分析1. 该程序可用于对学生的通讯方式基本信息的存储、更新、查询、输出等操作,以实现对学生通讯录信息的管理,便于同学之间的联系交往;2. 其中更新功能包括:添加信息,删除信息,修改信息,可根据需要添加一个或多个学生信息,也可针对个别学生信息进行适当的删除或修改,以便随时更新学生通讯信息。3. 程序中设计的查询功能可根据需要从若干数据中查询某个学生信息,并且可根据两种不同的方法查询:按姓名查询和按电话查询,以满足不同的需要;4. 可以通过输出的方式查看整个通讯录;5. 可以通过排序的方式查看同学生日的先后。四、概要设计1、方案设计对系统进行分析,给出结构图 分析:系统要实现许多功能,因此遵循结构化程序设计思想来进行本系统的设计:,自顶向下逐步细化,将系统设计任务分解出许多子功能模块来计;结构图如下:学生通讯录信息管理系统 选 择 模 块退出系统退出模块统计模块查询模块 更新模块 输出模块输入模块排序模块添加模块 删除模块修改模块按姓名按电话退出模块按省份按生日退出模块保 存 通 讯 信 息2 . 模块功能说明对各个模块进行功能的描述(1).输入模块:录入需要管理的通讯信息并将信息保存于文件中,以方便日后进行打印、读取、更新等操作。(2).添加模块:可添加一个或多个学生的通讯信息,并将所添加的信息保存,方便查找。(3).删除模块:可对失去联系的学生通讯信息做删除处理。(4).修改模块:可对通讯信息发生改变的学生信息进行修改。(5).查询模块:可对已建立的学生通讯信息进行查询,并且可根据需要选择按姓名查询或按电话查询。(6).保存模块:用于对通讯信息进行保存。(7).输出模块:将所有学生通讯信息或想要查询的学生信息显示于屏幕,用于打印学生通讯信息或查找某些学生通讯信息。(8).退出系统:选择该项,自动退出该系统。五、详细设计及运行结果流程图, 函数之间相互调用的图示 ,程序设计及编码, 运行结果。开 始输 入 变 量 i判断i的值统计模块查询模块 更新模块 输出模块输入模块退出模块添加模块 删除模块修改模块按姓名按电话退出模块按省份按生日退出模块排序模块判断i值输入变量退出模块输入变量判断i值输入变量判断i值保 存 模 块结 束 输入模块: 输入模块:开 始 开 始 i=0i=0isumisum输入通讯信息输入通讯信息i+i+m=y si.num!=0结 束sum=i结 束开始开始 排序模块: 更新模块:输入i的值i=0j=i+1判断i的值i的年龄大于j的年龄 否 退出系统删除模块修改模块添加模块 是 i=1 i=2 i=3 交换i与j的信息 j=j+1jsum 是 否返回主界面i=i+1 isum-1结束 是 否输出信息 结束输入i开始省份统计退出系统判断i值输入i开始退出系统判断i值查询模块: 统计模块:返回主界面结束姓名查询电话查询生日统计返回主界面结束六 调试情况及运行结果1.对自己设计进行评价,指出合理和不足之处,提出改进的方案。此次实践课编写的是一个应用程序,相对于以前我们见到的程序,它要大得多,运行的结果也没有预想中的好,数据的输出格式不太规范,而且各模块也出现了一些小问题,在同学们的帮助下,我很有耐心的一次又一次的进行修改,最后运行的结果基本上达到了预期的目的。可着毕竟是第一次独立完成这样的大程序,结果还不是太理想。由于时间很短,在选题报告中设想到的好多功能都没有实现。已有的那些功能虽已能基本上满足用户的需要,但如果还有更多的功能程序就会更加完美。如:再录入数据时,没有设计数据输入出错的提示。2.在设计过程中的感受。 本次c 语言的实习课让我对c 语言的学习又有了更深入的了解,也让我更深刻地领悟到了“实践出真理”这个道理,在上机实践过程中学到的知识远远超过了在课堂上十几周学到的,学校组织的这次实习让我们这些实践知识匮乏的大学生增添了许多社会经验,为我们将来走上工作岗位其了不小的铺垫作用。本次实习中遇到了很多以前没有遇到过的问题,也曾想过要放弃,但看到那些同学都在那认真的写程序,给了我继续的信心。在同学的帮助下,我顺利的结束了本次实习,让我知道原来凭借自己努力取得的成功会让自己这么欣慰,也让我知道了友谊和团结的重要性。并且,通过一种题材两中方式的学习,我掌握了更多的知识,也认识到对比学习的重要性。七参考文献参考书名 编者姓名 出版社 出版时间c语言程序设计 王曙燕 曹锰 科学出版社 2005年2月c语言程序设计 谭浩强 清华大学出版社 1999年12月 参考书名 编者姓名 出版社 出版时间c语言程序设计 王曙燕 曹锰 科学出版社 2005年2月八。附录:1. 链表方式: #include#include#define n sizeof(struct stud)#include #include #include /*日期结构体类型*/ struct date int y; int m; int d; bir; /*学生信息结构体类型*/ struct stud int num; /*序号*/ char name20; /*姓名*/ char tel40; /*电话*/ char addr40; /*省份*/ char yb20; /*邮编*/ char daxue50; /*大学*/ struct date bir; /*生日*/ struct stud *next; ; char a; struct stud *h; file *fp;/*建立链表*/struct stud *creat() int i,k; struct stud *p1,*p2,*head; printf(n请输入学生数:n); scanf(%d,&k); head=null; head=p1=p2=(struct stud *)malloc(n); /*head,p1,p2指向首结点*/ for(i=0;inum); printf(n请输入姓名:); scanf(%s,p1-name); printf(n请输入电话:); scanf(%s,p1-tel); printf(n请输入籍贯:); scanf(%s,p1-addr); printf(n请输入邮编:); scanf(%s,p1-yb); printf(n请输入大学:); scanf(%s,p1-daxue); printf(n请输入出生日期:(年-月-日); scanf(%d-%d-%d,&p1-bir.y,&p1-bir.m,&p1-bir.d); p2-next=p1; /*将新结点链接到表尾*/ p2=p1; /*p2指向新的表尾*/ p2-next=null; head=head-next; /*头指针后移*/ save_message(head); /*立即保存*/ return head;/*输入模块*/input_message()clrscr(); printf(nn*输入学生信息*n); printf(-n); h=creat(); bioskey(0); printf(输入完毕,按任意键返回主菜单!); bioskey(0);/*输出模块*/output_message(struct stud *p)clrscr(); if(p=null) printf(暂无信息!请回主菜单录入信息!n); else printf(nn=通讯录信息表=nn); printf(姓名=省份=电话=生日(年-月-日)=邮编=大学n); while(p!=null) printf(-n); printf(%s %s %s %d-%d-%d %s %sn,p-name,p-addr,p-tel,p-bir.y,p-bir.m,p-bir.d,p-yb,p-daxue); printf(-n); printf(n); p=p-next; printf(n); printf(按任意键返回主菜单!nn); bioskey(0);/*保存学生信息*/save_message(struct stud *h)file *fp; struct stud *f; f=h; /*保证指针位置*/ if(fp=fopen(zhuyan.txt,wb)=null) printf(不能打开文件!n); return; while(h!=null) if(fwrite(h,sizeof(struct stud),1,fp)!=1) /*向文件写入数据*/ printf(文件写入错误!); return; h=h-next; h=f; /*保证指针位置*/ printf(已存盘,按任意键回上层菜单:n); getch(); fclose(fp); return;/*读取信息*/read_message()file *fp; if(fp=fopen(zhuyan.txt,rb)=null) printf(nn*暂时还没有该生信息,请按任意键返回上一级菜单.n); return; do if(fread(h,sizeof(struct stud),1,fp)!=1) if(feof(fp) printf(已到文件末尾.n); /*已到文件末尾.*/ else printf(文件读取错误!n); /*文件读取错误.*/ return; h=h-next; while(h!=null); fclose(fp); getch(); bioskey(0);/*添加学生信息*/add_message(struct stud *w) struct stud *p,*q; p=(struct stud*)malloc(n); /*p指向新申请的结点*/ clrscr(); printf(n请输入学生序号:); scanf(%d,&p-num); printf(n请输入学生姓名:); scanf(%s,p-name); printf(n请输入学生电话:); scanf(%s,p-tel); printf(n请输入学生籍贯:); scanf(%s,p-addr); printf(n请输入学生邮编:); scanf(%s,p-yb); printf(n请输入学生大学:); scanf(%s,p-daxue); printf(n请输入学生出生日期:); scanf(%d-%d-%d,&p-bir.y,&p-bir.m,&p-bir.d); p-next=null; if(w=null) w=p; /*头指针为空,p作为新头指针*/ return 1; /*正确插入返回1*/ q=w; /*从头指针开始*/ if(q-num)(p-num) /*找到插入位置在首结点之前*/ p-next=w; /*将首结点链接在新结点之后*/ w=p; /*p作为新的头指针*/ return 1; while(q-next)!=null & (q-next-num)num) q=q-next; /*继续查找插入位置*/ if(q-next=null) /*插入位置在尾结点之后*/ q-next=p; /*新结点链接到尾结点之后*/ return 1; else if(q-next-num)=(p-num) /*找到重号*/ free(p); /*释放新结点的存储空间*/ return 0; /*不插入返回0*/ p-next=q-next; /*后续结点链接到新结点之后*/ q-next=p; /*新结点链接到前驱结点之后*/ return 1;/*删除模块*/del_message(struct stud *w)char name20; struct stud *p,*q; if(w=null) return 0; /*w就是头指针,空表不能删除返回0*/ clrscr(); printf(请输入要删除的学生姓名:n); scanf(%s,name); q=w; if(strcmp(q-name,name)=0) /*找到要删除的是第一个结点*/ w=q-next; /*修改头指针*/ free(q); /*释放存储空间*/ return 1; /*正确删除返回1*/ p=q-next; while(p!=null) if(strcmp(p-name,name)=0) /*找到要删除的结点*/ q-next=p-next; /*后续结点连接到前驱结点之后*/ free(p); /*释放存储空间*/ return 1; q=p; /*推移指针继续查找*/ p=p-next; return 0; /*未找到要删除的结点返回0*/*修改模块*/revise_message(struct stud *g) int choice; char name20,n,m; do clrscr(); printf(n *学生学籍信息* n); printf( 输入要修改的学生姓名:n); scanf(%s,name); while(g!=null) while(strcmp(g-name,name)!=0) g=g-next; if(g=null) printf(n 该学生不存在!); bioskey(0); else do printf(n 您要修改哪一项?n); printf(n 1序号n); printf(n 2姓名n); printf(n 3籍贯n); printf(n 4电话n); printf(n 5大学n); printf(n 6出生日期n); scanf(%d,&choice); switch(choice) case 1:printf(n 请输入修改后的序号:); scanf(%d,&g-num);break; case 2:printf(n 请输入修改后的姓名:); scanf(%s,g-name);break; case 3:printf(n 请输入修改后的籍贯:); scanf(%s,g-addr); break; case 4:printf(n 请输入修改后的电话:); scanf(%s,g-tel); break; case 5:printf(n 请输入修改后的大学:); scanf(%s,g-daxue); break; case 6:printf(n 请输入修改后的出生日期:); scanf(%d-%d-%d,&g-bir.y,&g-bir.m,&g-bir.d);break; printf(n是否继续修改此人信息?y/nn) ; getchar(); m=getchar(); while(m=y); printf(nn=通讯录信息表=nn); printf(姓名=省份=电话=生日(年-月-日)=邮编=大学n); printf(-n); printf(%s %s %s %d-%d-%d %s %sn,g-name,g-addr,g-tel,g-bir.y,g-bir.m,g-bir.d,g-yb,g-daxue); printf(-n); printf(n); getch(); break; printf(n要继续吗?(y/n)n); getchar(); n=getchar(); while(n=y); printf(n 按任意键返回主菜单!); bioskey(0); /*更新模块*/ renew_message() int choice=100; while(choice!=0) printf(n*更新同学信息*nn); printf( 1.添加同学信息nn); printf( 2.删除同学信息nn); printf( 3.修改同学信息nn); printf( 0.返回修改菜单nn); printf( 请选择(03):n); printf(*nn); scanf(%d,&choice); switch(choice) case 1:add_message(h);break; case 2:del_message(h);break; case 3:revise_message(h);break; case 0:break; default:printf(输入有误!n); /*按姓名查询*/inquire_name( struct stud *p) char name20; struct stud *f; f=p; clrscr(); printf(nn 请输入要查找的姓名:); scanf(%s,&name); if(p=null) printf(n您要查找的学生暂时不存在,请按任意键返回n); bioskey(0); else if (strcmp(p-name,name)!=0|p-name=null) p=p-next; clrscr(); printf(nn该生有关信息为:nnnn); printf(nn=通讯录信息表=nn); printf(姓名=省份=电话=生日(年-月-日)=邮编=大学n); printf(-n); printf(%s %s %s %d-%d-%d %s %sn,p-name,p-addr,p-tel,p-bir.y,p-bir.m,p-bir.d,p-yb,p-daxue); printf(-n); printf(n); p=f; getch();/*按学号查询*/inquire_tel(struct stud *p)char tel20; struct stud *f; f=p; clrscr(); printf(n 请输入要查找的电话:); scanf(%s,&tel); if(p=null) printf(n您要查找的学生暂时不存在,请按任意键返回n); bioskey(0); else if(strcmp(p-tel,tel)!=0|p-tel=null) p=p-next; clrscr(); printf(nn该生有关信息为:nnnn); printf(nn=通讯录信息表=nn); printf(姓名=省份=电话=生日(年-月-日)=邮编=大学n); printf(-n); printf(%s %s %s %d-%d-%d %s %sn,p-name,p-addr,p-tel,p-bir.y,p-bir.m,p-bir.d,p-yb,p-daxue); printf(-n); printf(n); p=f; getch(); /*查询模块*/ inquire_message() int choice=100; while(choice!=0) printf(n*查询同学通讯信息*n); printf( 1.按同学姓名查询:n); printf( 2.按同学电话查询:n); printf( 0.返回主菜单:n); printf( 请选择(02):n); scanf(%d,&choice); switch(choice) case 1:inquire_name(h);break; case 2:inquire_tel(h);break; case 0:break; default:printf(无此类查询方式!n); /*省份统计*/ count_ad(struct stud *p) int count=0; char count_ad20; printf(n 输入要统计的省份名称:n); scanf(%s,count_ad); if(p=null) printf(n 该学生不存在!); bioskey(0); else printf( 在该省份的同学:n); printf(姓名=省份=电话=生日(年-月-日)=邮编=大学n); printf(-n); p=h; /*p指向头指针!*/ while(p!=null) if(strcmp(p-addr,count_ad)=0) printf(%s %s %s %d-%d-%d %s %sn,p-name,p-addr,p-tel,p-bir.y,p-bir.m,p-bir.d,p-yb,p-daxue); p=p-next; count+; printf(在这个省份的同学共有%d个,count); /*生日统计*/ count_birthday(struct stud *p) int count=0; int count_birthday_month; printf( 请输入要统计的月份:n); scanf(%d,&count_birthday_month); if(p=null) printf(n 该学生不存在!); bioskey(0); else printf( 在这个月过生日的同学:记得祝贺他们生日快乐!n); printf(姓名=省份=电话=生日(年-月-日)=邮编=大学n); printf(-n); p=h; while(p!=null) if(p-bir.m=count_birthday_month) printf(%s %s %s %d-%d-%d %s %sn,p-name,p-addr,p-tel,p-bir.y,p-bir.m,p-bir.d,p-yb,p-daxue); p=p-next; count+; printf(在这个月过生日的同学有%d个,count); /*统计模块*/ count_message() int choice=100; while(choice!=0) printf(nn*统计同学通讯信息*n); printf( 1.按省份统计信息;n); printf( 2.按生日统计信息;n); printf( 0.返回主菜单;n); printf( 请选择(0-2):n); scanf(%d,&choice); switch(choice) case 1:count_ad(h);break; case 2:count_birthday(h);break; case 0:break; default:printf(输入有误!n); /*主程序*/main() int b; printf(输入任意键进入。nn); bioskey(0); do clrscr(); printf(nnn *欢迎进入* nn); printf( * 学生通讯录管理系统 *nn); printf( * 1输入学生信息 *nn); printf( * 2输出学生信息 *nn); printf( * 3更新学生信息 *nn); printf( * 4查询学生信息 *nn); printf( * 5统计学生信息 *nn); printf( * 6保存信息 *nn); printf( * 7读取信息 *nn); printf( * 0退出系统 *nn); printf( * 请选择(07) : *nn); scanf(%d,&b); switch(b) case 1: input_message(); break; case 2: output_message(h); break; case 3: renew_message(); break; case 4: inquire_message(); break; case 5: count_message(); break; case 6: save_message(h); break; case 7: read_message(); break; case 0: break; while(b!=0);2数组方式:#include #include #define max 200#define n 9 int sum; /*日期结构体类型*/ struct b_type int year; /*年*/ int month; /*月*/ int day; /*日*/ ; /*通讯录结构体类型*/ struct s_type int num; /*序号*/ char name20; /*姓名*/ char address20; /*省份*/ char tel
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- GB/T 20130-2025自屏蔽电子束辐射加工装置
- 火灾人身伤害应急预案(3篇)
- 加油车火灾应急预案(3篇)
- 信息处理技术员考试实操题目及答案
- 活动室火灾应急疏散预案(3篇)
- 行政法规与内部管理规章关系试题及答案
- 行政法学备考过程中的情绪管理技巧:试题及答案
- 企业文化与战略执行的协同试题及答案
- 行政管理中客户关系与法律服务的整合试题及答案
- 平台即服务与基础设施即服务试题及答案
- 小小科学家《物理》模拟试卷A(附答案)
- 体能科学训练方法智慧树知到期末考试答案2024年
- 四川民歌智慧树知到期末考试答案2024年
- 休克的超声评估
- 高中生物必修二全套课件
- 安踏案例分析
- 四年级下册语文文言文阅读理解专项精选练习
- 五年级人教PEP版英语下册连词成句专项积累练习
- T_CHES 18-2018 农村饮水安全评价准则
- 欧盟RoHS2.0指令附件III及附件IV豁免清单(45页)
- 关于民主评议市卫健委工作的评议报告
评论
0/150
提交评论