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

加入VIP,免费下载
 

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

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

下载须知

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

版权提示 | 免责声明

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

通讯录查询系统课程设计.docx

1、通讯录查询系统课程设计数据结构课程设计报告信息工程学院计算机科学与技术专业单位员工通讯录管理系统(线性表应用)计算机093班第2组组员:姓名:林鸿 学号:*姓名:张明 学号:*姓名:周龙 学号:*指导教师:*日期:2011年1月2日程序设计书目录一、程序设计目标二、问题描述三、需求分析(说明课程设计的任务)四、概要设计(说明课程设计中用到的抽象数据类型的定义、主程序的流程以及各程序模块之间的调用关系等)五、详细设计(实现程序模块的具体算法)六、软件说明书(给出软件应如何使用,使用时的具体事项)七、源程序清单(要求400行以上,要有注释说明) 八、测试报告(调试过程中遇到的问题以及解决方法,并列

2、出测试结果,包括输入和输出)九、课程设计总结一:程序设计目标通过对通讯录管理链表的课程设计,加深对程序设计的理解,熟练掌握和加深c语言的基本知识和语法规范,同时更进一步地理解数据结构对单链表知识的应用,培养我们调查研究、查阅技术文献、资料、手册以及编写程序的能力,同时也考验我们善于思考,互相帮助的团队精神。本程序是学会建立通讯录,使人员之间联系更加方便快捷,增加办事效率。二:问题描述为某个单位建立一个员工通讯录管理系统,可以方便查询每一个员工的办公室电话、手机号及电子邮箱。其功能包括通讯录链表的建立、员工通讯信息的查询、修改、插入与删除、以及整个通讯录的输出。三:需求分析想要建立一个单位员工通

3、讯录的管理系统,方便查询其每个员工的一些信息。首先,应运用c语言中结构体的知识。把员工的各项信息储存到结构体的链表中,定义一个新的结构体类型struct(struct是声明结构体时所必须使用的关键字)它向编译系统声明这是一个“结构体类型”,它包括num, name ,phone等不同类型的数据项。其次:运用数据结构中线性表的知识。线性表的存储结构分为线性表的线性存储结构和线性表的链式存储结构, 线性表的顺序存储结构是指用一组地址连续的存储单元一次存储线性表的数据元素。线性表的链式存储结构则是通过指针反映元素之间的关系,不要求逻辑上相邻的元素在物理位置上也相邻,所以该方法可以克服顺序表的一些缺点

4、。所以本题应运用线性链表的链式存储结构。线性链表的链式存储结构又分为单链表、循环链表和双链表,本题运用单链表的知识。1:通讯录链表的建立。 建立单链表有两种方法,头插入法和尾插入法。头插入法是将每次新插入的结点插入在链表的表头,而尾插入法是将新插入的结点插入到链表的表尾。在这个通讯录的建立中将采用尾插入法建立链表。2:链表的插入。链表结点的插入是要求将一个通讯录数据结点按其编号的顺序插入有序通讯录表的相应位置,以保持其有序性。使用两个指针变量分别指向刚访问的结点和下一个结点,寻找插入结点的位置,其中一个指向待插入位置的前一个结点。3:单链表的删除。输入要查找的通讯录的编号或者姓名,从表头顺序访

5、问表中结点,查找成功则返回指向查找的通讯者信息的结点,删除结点即可。4:链表的查询。 首先输入要查找的通讯录的编号、姓名、办公室电话号或手机号码,从表头顺序访问表中结点,查找成功则返回指向查找的通讯者信息的结点,否则返回一个空的指针。5:通讯录的输出。 将表头指针赋给一个指针变量,然后用其向后扫描,直至表尾,指针为空为止。6:员工信息的修改。 首先通过链表的查询找到要修改的结点,找到后就可以对员工的姓名、办公室电话号码、手机号码、电子邮箱任意一项进行改。四:概要设计 (1)本程序主要应用了结构体、指针,函数调用,和单链表的有关知识。 定义通讯者的结点类型:typedef struct char

6、 num5;/员工编号 char name15;/员工姓名 char phone15;/员工办公室电话号码 char call15;/员工手机号码 char e_mail30;/员工电子邮箱DataType;线性表的链式存储结构定义:typedef struct node /结点类型定义 DataType data; /结点数据 struct node *next; /结点指针域Dnode;Dnode *head;/ 定义指向单链表的头指针Dnode *p; /定义一个指向结点的指针变量函数声明:int menu ();/主菜单Dnode *createlist();/创建void Add(D

7、node *head,Dnode *p);/插入Dnode *research(Dnode *head);/查找void Delete(Dnode *head);/ 删除Dnode *Change(Dnode *head, char k);/修改void printlist(Dnode *head);/输出void Saveandfree(); /*保存到文件*/void Open(); /*打开文件*/(2)进入菜单选择函数,有0-6可以选择,选择1,则调用尾插入法建立通讯录链表函数Dnode *CreateList();选择2,则调用通讯录链表head中插入结点函数void Add(Dno

8、de *head,Dnode *p);选择3,则调用通讯录链表上结点的删除函数void Delete(Dnode *head);选择4,则调用有序通讯录链表上的查找函数Dnode *research(Dnode *head),选择5,则调用通讯录链表的输出函数 void Print_List(Dnode *head);选择6,则调用修改员工信息函数Dnode * Change(Dnode *head, char k);选择0,则调用保存并退出系统函数,整个程序流程结束。五详细设计 首先应编写一个菜单程序。int menu() int i; printf( ); printf(n); print

9、f( 通讯录系统清单n ); printf(n); printf( ); printf(n); printf( 1.通讯录的建立); printf(n); printf( 2.添加人员信息); printf(n); printf( 3.删除人员信息); printf(n); printf( 4.查询人员信息); printf(n); printf( 5.输出人员信息); printf(n); printf( 6.修改人员信息); printf(n); printf( 0.退出并保存); printf(n); printf(请选择0-6:); scanf(%d,&i); while(i6) pr

10、intf(系统提示: 您输入错误!n); /提示输入是否错误 printf(请重新输入0-6: ); scanf(%d,&i); printf(nn); return i;然后主函数调用返回值i,再到switch语句中进行相应的选择,进行模块处理。 Open(); while(1) switch(menu() case 1: printf( ); printf(n); printf( 通 讯 录 链 表 的 建 立 ); printf(n); printf( ); printf(n); /建立通讯录链表的函数调用 head=createlist(); break; case 2: p=(Dno

11、de *)malloc(sizeof(Dnode); printf( ); printf(n); printf( 通 讯 者 信 息 的 添 加 ); printf(n); printf( ); printf(n); printf(员工编号: n); scanf(%s,p-data.num); printf(员工姓名: n); scanf(%s,p-data.name); printf(员工办公室电话号码: n); scanf(%s,p-data.phone); printf(员工手机号码: n); scanf(%s,p-data.call); printf(员工电子邮箱: n); scanf

12、(%s,p-data.e_mail); printf(操作已成功!n); Add(head,p); break; case 3: printf( ); printf(n); printf( 通 讯 录 信 息 的 删 除 ); printf(n); printf( ); printf(n); /通讯者删除函数的调用 Delete(head);/删除结点 break; case 4: printf( ); printf(n); printf( 通 讯 录 信 息 的 查 询 ); printf(n); printf( ); printf(n); /通讯者查询函数的调用 p=research(he

13、ad); if(p!=NULL) printf(编号 姓名 办公室电话 手机号码 邮箱); putchar(n); printf(%-5st,p-data.num); printf(%-10st,p-data.name); printf(%-10st,p-data.phone); printf(%-10st,p-data.call); printf(%-15stn,p-data.e_mail); printf(n); else printf(对不起没有您要查询者的信息n); break; case 5: printf( ); printf(n); printf( 通 讯 录 的 输 出 );

14、printf(n); printf( ); printf(n); /通讯录链表输出函数调用 print_list(head); break; case 6: char c=getchar(); char b5; printf( ); printf(n); printf( 通 讯 录 的 修 改 ); printf(n); printf( ); printf(n); Change(head,b); break; case 0:Saveandfree(); /*保存并释放内存*/ exit(0); break; 第三步是模块的分步处理,其中分为通讯录链表的建立、插入、删除、查询、输出、修改、退出。

15、六、软件说明书(给出软件应如何使用,使用时的具体事项)打开开始菜单找到VC+6.0,打开此软件,用鼠标单击文件菜单里的打开选项,导入文件,按ctrl+f7,看文件是否有错误,如果没有错误按ctrl+f5进行运行。首先在运行程序是弹出菜单供我们进行选择1通讯录的建立2添加人员信息3删除人员信息4查询人员信息5输出人员信息6修改人员信息0退出并保存这里我们先选择1进行通讯录的建立,会出现我们要建立的内容。请输入编号:请输入姓名:请输入办公室电话:请输入手机号码:请输入电子邮箱:我们根据提示,进行相应的填写即可。填写完毕后,系统会提示“要继续创建请按(n),结束创建请按其它键”如果我们选择n则继续进

16、行编写。然后我们可以选择2,进行通讯录链表的插入,过程同建立相似。如果我们选择3,就进行通讯录链表的删除,这里我们可以按编号删除,也可以按姓名删除,只需要填写要删除人的编号或者姓名就可以删除该人的信息内容。如果我们选择4,就进行通讯录链表的查询,其中也分为按编号和姓名、办公室电话、手机号码查询四种。如果我们选择5,则输出全部人员内容的清单。如果我们选择6,就进行结点信息的修改。修改先是通过查找函数找到要修改的信息,在对找的的信息进行修改,修改的内容包括:姓名、办公室电话号码、手机号码、电子邮箱。六、源程序清单(要求400行以上,要有注释说明)#include #include #include

17、/定义结构体变量 typedef struct char num5; char name15; char phone13; char call15; char e_mail30;datatype;/结点类型定义typedef struct node /结点数据域 datatype data; /结点指针域 struct node * next;Dnode;Dnode *head;Dnode *p;typedef struct node linklist;/linklist *Head=NULL;/菜单函数int menu();/创建通讯单链表函数Dnode *createlist();/插入函

18、数void Add(Dnode *head,Dnode *p);/查找函数Dnode *research(Dnode *head);/删除函数void Delete(Dnode *head);/显示所有信息函数void print_list(Dnode *head);/修改信息Dnode *Change(Dnode *head,char k);void Saveandfree(); /*保存到文件*/void Open(); /*打开文件*/菜单函数int menu() int i; printf( ); printf(n); printf( 通讯录系统清单n ); printf(n); pr

19、intf( ); printf(n); printf( 1.通讯录的建立); printf(n); printf( 2.添加人员信息); printf(n); printf( 3.删除人员信息); printf(n); printf( 4.查询人员信息); printf(n); printf( 5.输出人员信息); printf(n); printf( 6.修改人员信息); printf(n); printf( 0.退出并保存); printf(n); printf(请选择0-6:); scanf(%d,&i); while(i6) printf(系统提示: 您输入错误!n); /提示输入是否

20、错误 printf(请重新输入0-6: ); scanf(%d,&i); printf(nn); return i;/尾插法建立带头结点的通讯录链表算法Dnode *createlist()Dnode *head=(Dnode *)malloc(sizeof(Dnode);/申请头结点Dnode *p;Dnode *rear;char c=n;/尾指针初始指向头结点 rear=head;while(c=n) p=(Dnode *)malloc(sizeof(Dnode); printf(请输入编号: n); scanf(%s,p-data.num); printf(请输入姓名: n); sca

21、nf(%s,p-data.name); printf(请输入办公室电话: n); scanf(%s,p-data.phone); printf(请输入手机: n); scanf(%s,p-data.call); printf(请输入电子邮箱: n); scanf(%s,p-data.e_mail); /新结点连接到尾结点之后 rear-next=p; /尾指针指向新结点 rear=p; printf(要继续创建请按(n),结束创建请按其它键: n); /读入一个标志数据 scanf(%c,&c); /终端结点指针域置空 rear-next=NULL; /返回链表头指针 return head;

22、/插入函数void Add(Dnode *head,Dnode *p) Dnode *p1; Dnode *p2; p1=head; p2=p1-next; while(p2!=NULL&strcmp(p2-data.num,p-data.num)next; /插入p所指向的结点 p1-next=p; /连接表中剩余部分 p-next=p2;void Delete(Dnode *head) char a,b; Dnode *p; Dnode *q; char num5; char name10; int x; printf(1.按编号删除 n); printf(2.按姓名删除n ); prin

23、tf(请选择(1或2): ); p=head-next; scanf(%d,&x); if(x=1) printf(请输入要查询者的编号:); scanf(%s,num); while(p&strcmp(p-data.num,num)next; if(p=NULL|strcmp(p-data.num,num)0) p=NULL; if(x=2) printf(请输入要查询者的姓名:); scanf(%s,name); while(p&strcmp(p-data.name,name)!=0) p=p-next; scanf(%c,&b); if(p=NULL) printf(对不起没有您要查询者

24、的信息n); return; printf(要删除该结点吗?(y/n) :); scanf(%c,&a); if(a=y|a=Y) q=head; while(q!=NULL&q-next!=p) q=q-next; /删除结点 q-next=p-next; /释放被删除的结点空间 free(p); printf(通讯者已经被删除 n); /通讯链表上的查找Dnode *research(Dnode *head) Dnode *p; char num5; char name10; char phone15; char call15; int x; printf(1.按编号查询:n); prin

25、tf(2.按姓名查询:n); printf(3.按电话号码查询:n); printf(4.按手机号码查询:n); printf(请选择(1-4): ); p=head-next;/有头结点 scanf(%d,&x); if(x=1) printf(请输入要查询者的编号:); scanf(%s,num); while(p&strcmp(p-data.num,num)next; if(p=NULL|strcmp(p-data.num,num)0) /没有查到要查找的通讯者 p=NULL; if(x=2) printf(请输入要查询者的姓名:); scanf(%s,name); while(p&strcmp(p-data.name,name)!=0) p=p-next; if(x=3) printf(请输入要查询者的办公室电话号码:); scanf(

copyright@ 2008-2022 冰豆网网站版权所有

经营许可证编号:鄂ICP备2022015515号-1