精品资料(2021-2022年收藏)课程设计旅游管理系统和B树的实现_第1页
精品资料(2021-2022年收藏)课程设计旅游管理系统和B树的实现_第2页
精品资料(2021-2022年收藏)课程设计旅游管理系统和B树的实现_第3页
精品资料(2021-2022年收藏)课程设计旅游管理系统和B树的实现_第4页
精品资料(2021-2022年收藏)课程设计旅游管理系统和B树的实现_第5页
已阅读5页,还剩44页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、 课 程 设 计 -数据结构课程设计报告 学 号 : 1016020203 姓 名 : 张 灿 指导教师 : 曹春萍 专 业 : 计算机 完成日期 : 2012.06.25 目 录 A篇:旅游信息管理系统1、 题目要求 1、题目内容-12、 程序设计目标 1、题目分析-1 2、功能简介-2 3、数据结构-23、 概要简述 1、功能结构图-3 2、模块分析-34、 详细设计 1、结构体定义-3 2、程序流程图 -55、 源程序代码 1、源程序c+实现代码-66、 调试分析及测试结果 1、运行结果截-147、 附录 1、补充说明-198、 程序小结 1、报告总结19 B篇: B-树手工题1、 题目

2、要求 1、题目内容-202、 运行过程 1、从空树插入-20 2、插入完成-25 3、依次删除要求点-26 4、最终结果-28 C篇:附加题1、 题目 1、题目内容292、 程序设计目标 1、功能简介29 2、数据结构293、 设计思路 1、结构体定义29 2、功能结构图30 3、程序流程图304、 实现代码 1、程序代码325、 程序调试以及运行结果 1、调试结果及截图436、 报告总结 1、报告总结44 44 A篇:旅游信息管理系统1、 题目要求1、 题目内容 旅游信息管理系统 1)数据结构 (1)、二叉排序树加单链表 (2)、二叉排序树 说明:1、用二叉排序树表示旅游地点,用单链表表示游

3、客。 2、用二叉排序树表示旅游地点和游客。 2)、功能 (1)、旅游地点的插入 (2)、游客报名 (3)、当某地的旅游人数少于三个人时,取消次旅游地,建议游客该选其他旅游点 (4)、当某旅游地旅游人数等于六个时,不允许在报名。 建议游客改选其它旅游地。 2、 程序设计目标 1、题目分析 读题可知,需完成两方面的编程以对旅游系统进行操作。一方面是旅游公司管理人员,主要是旅游景点的添加与删除,对旅游人员的录入与删除,对旅游人数的统计,把游客所需信息打印等等;第二方面是游客对于旅游地的选、改、删,以及个人信息的输入、确认等等。 2、功能简介 由以上分析可得:本设计程序功能主要有: 、 旅游公司管理人

4、员对旅游人员和旅游地点的操作,用二叉排序树管理旅游地点。主要有地点的变更,插入、删除、游客的信息存储及及时提醒等功能。其中二叉树每一个结点包括旅游地点的区号(area_node)、名称(area)、该旅游地的游客人数(count)、以及一个指向游客信息结构的指针(list),还有二叉树结点的左孩子和右孩子指针(lchild,rchild)。 、 游客可以登陆旅游公司界面进行报名、选择旅游地点和输入个人信息。游客结构采用单链表,其中包括单链表的初始化、插入、删除、计数功能。其中每一个单链表结点包括游客的编号(id)、姓名(name)、性别(sex)、和链接链表的指针(next)。 3、数据结构用

5、到的数据结构有:单链表,排序二叉树,数组。3、 概要简述 1、功能结构图 主 菜 单 程序员 游客删除遍历插入遍历插入 二叉树单链表 2、模块分析工作去选择模块 本程序包括三个模块:主程序模块、二叉排序树模块、单链表模块,工作区选择模块。如图: 二叉排序树模块 主程序模块 单链表模块 4、 详细设计 1、结构体定义 1)、链表结点结构体typedef struct touriststring name;int id;string sex;struct tourist *next;Trist,*linklist;左孩子 区号 地名 游客数 右孩子 指向链表的指针 2)、二叉排序树结点结构体typ

6、edef struct Tree_Placeint area_code; /旅游地区号string area; /旅游地名称int count; /记录该旅游地报名游客人数struct Tree_Place *lchild,*rchild; Trist *list; /指向游客所在单链表的指针 Place,*TPlace; 左孩子 区号 地名 游客数 右孩子 指向链表的指针2、程序流程图 主 菜 单(1、程序员,2、游客) 1 输入密码 错误 正确 (12345) 2 程序管理员 游 客退出显示少于3人地查询各地游客数目输入地点退出输入旅游地区号显示所有旅游地查询可报名地修改旅游地点删除超额可

7、报提醒删除打印退出 输入退出可报地输入信息重复 提醒 成功退/输 Y N 报名成功 N打印个人信息 Y 5、 源程序代码 1、源程序c+实现代码#include#include#include#includeusing namespace std;#define MAX 50#define SIZE 12typedef struct tourist char nameSIZE; int id; char sex5; struct tourist *next;Trist,*linklist;typedef struct Tree_Place int code; /旅游地区号 char areaS

8、IZE; /旅游地名称 int count; /记录该旅游地报名游客人数 struct Tree_Place *lchild,*rchild; Trist *list; /指向游客所在单链表的指针 Place,*TPlace;void Search_T(TPlace &tree,int co);void Mainlist(TPlace &tree);void Tour_1(TPlace &tree);void Tour_2(TPlace &tree);void Destory(TPlace &tree);void Init_L(linklist &head) head=NULL;void In

9、sert_L (TPlace &tree,TPlace &t,linklist &head) linklist tr; char c; int i=1,co,id; while(t-count6&i=1) cout请输入你的身份证号:id; tr=(linklist)malloc(sizeof(Trist); tr-id =id; cout输入姓名,性别:tr-nametr-sex; tr-next=head; head=tr;t-count+; cout继续报名请按1,按0退出!i; if(t-count=6) cout此旅游地人数已满,按y选择其他旅游地,其他键退出!c; if(c=y|c

10、=Y) cout请重新输入区号co;Search_T(tree,co); else Tour_2(tree);void Delet_L (linklist &head) linklist p,pro; pro=head; while(pro) p=pro ;pro=p-next ;free(p); void Insert_T(TPlace &tree,TPlace p) /在二叉排序树中插入一个新结点 if (tree=NULL) tree=p; else if(p-codecode) Insert_T(tree-lchild,p); else if(p-codetree-code) Inse

11、rt_T(tree-rchild,p);void Search_T(TPlace &tree,int co) char c; TPlace p; int code; p=tree; while(p&p-code!=co ) if(p-codeco) p=p-lchild ; else p=p-rchild ; if(!p) cout此旅游地点还未存在!count=6) cout此旅游地人数已满,按y选择其他旅游地,其他键退出!c; if(c=y|c=Y) cout请重新输入区号code;Search_T(tree,code);else Tour_2(tree); else cout可以报名li

12、st);Tour_2(tree);TPlace Delete_T(TPlace &t,int co) TPlace p,parent,s,q;/parent指向要删除的节点的双亲,p指向要删除的节点 p=t; parent=NULL; while(p) if(p-code=co) break; parent=p; if(p-codeco) p=p-lchild; else p=p-rchild; if(p=NULL) /不存在该树节点 return t; if(p-lchild=NULL) /无左子树,右子树可有可无 if(parent=NULL) t=p-rchild; else if(pa

13、rent-lchild=p) parent-lchild=p-rchild; else parent-rchild=p-rchild; Delet_L (p-list); free(p); else /有左子树,右子树可有可无 q=p; s=q-lchild; / while(s-rchild) q=s; s=s-rchild; if(q=p) /其左孩子没有右子树 q-lchild=s-lchild; else q-rchild=s-lchild; p-code=s-code; Delet_L (s-list); free(s); return t; void Fun1(TPlace &tr

14、ee) char c; int n; TPlace p; cout请输入插入地点个数:n; cout依次输入各个旅游地点的区号和地名:endl; for(int i=0;in;i+) p=(TPlace)malloc(sizeof(Place); cout请输入第i+1个地点:p-codep-area ; p-lchild =p-rchild =NULL; p-list=NULL; p-count =0; Insert_T(tree,p); coutc; if(c=y|c=Y) Fun1(tree); else system(cls);Tour_1(tree);void Fun2(TPlace

15、 &tree,int x) int top=0; TPlace p,sMAX; p=tree; while(p|top0) while(p) stop+=p; p=p-lchild; if(top0) p=s-top;coutsetw(8)区号:codesetw(10)地名:areasetw(10)人数:countrchild; if(tree=NULL)cout还未录入旅游地!请稍后查询!endl; cout按任意键返回上一级菜单!0) while(p) stop+=p; p=p-lchild; if(top0) p=s-top; if(p-count3&x=1) coutsetw(8)区号

16、:codesetw(10)地名:areasetw(10)人数:countcode ;n1+; if(p-count6&x=2) coutsetw(8)区号:codesetw(10)地名:areasetw(10)人数:countrchild; if(x=1)cout一共有n1各旅游景点人数少于三个endl;cout删除旅游地请输入D或者d,其他键返回菜单!c; if(c=d|c=D) for(int i=0;in1;i+) Delete_T(tree,elemi);cout删除完成!endl; system(pause);Tour_1(tree); if(x=2)cout一共有n2个旅游景点仍可

17、报名endl;cout按任意键返回上一级菜单!endl;system(pause);Tour_2(tree); void Fun4(TPlace &tree) int co,id;TPlace p; linklist l,pre; p=tree; cout输入要退出旅游地的区号和自己的身份证号:coid; while(p&p-code!=co ) if(p-codeco) p=p-lchild ; else p=p-rchild ; if(!p) cout此旅游地点还未存在!list;pre=l; while(l-id!=id) pre=l; l=l-next; pre-next=l-next

18、;free(l);p-count-;cout输入要报名的地点区号:co;Search_T(tree,co); void Mainlist(TPlace &tree) system(cls); cout *endlendl; cout 欢迎登陆旅游购票系统endl; cout 请选择登录身份:endl; cout 1、旅游公司管理人员endl; cout 2、游客endl; cout 3、退出 程序endl; cout *endln; switch(n) case 3: Destory(tree);exit(0); case 1: docoutkey;i+; while(key!=12345&i

19、=3); if(key=12345) Tour_1(tree);else Mainlist(tree);break; case 2: Tour_2(tree);break; default :cout输入错误,请重新选择!endl;system(pause); Mainlist(tree); void Tour_1(TPlace &tree) system(cls); int n; cout *endlendl; cout 1、输入旅游地点 endl; cout 2、查询各旅游地游客人数endl; cout 3、显示不足三人的旅游地endl; cout 4、退出endl; cout *endl

20、n; switch(n) case 1: Fun1(tree);break; case 2: Fun2(tree,1);break; case 3: Fun3(tree,1);break; case 4: Mainlist(tree);break; default :cout输入错误,请重新输入!endl;system(pause);Tour_1(tree); void Tour_2(TPlace &tree) int code; system(cls); int n; cout *endlendl; cout 1、输入旅游地区号 endl; cout 2、显示所有旅游地endl; cout

21、3、查询可报名地endl; cout 4、修改旅游地点endl; cout 5、退出endl; cout *endln; switch(n) case 1: cout请输入区号:code;Search_T(tree,code);break; case 2: Fun2(tree,2);break; case 3: Fun3(tree,2);break; case 4: Fun4(tree);break; case 5:Mainlist(tree);break; default :cout输入错误,请重新输入!endl;system(pause);Tour_2(tree); /销毁二叉树void

22、Destory(TPlace &tree)if(!tree) cout此树已空!lchild)Destory(tree-lchild);if(tree&tree-rchild)Destory(tree-rchild);coutsetw(5)codesetw(5)arealist);free(tree);void main() TPlace T=NULL; Mainlist(T);六、调试分析及测试结果 1、运行结果截图七、附录 1、补充说明 #include :包含分配空间的头文件 #include :包含对字符串进行操作的头文件#include :包含控制输出格式的头文件Destory 函数

23、为释放内存,删除所建树的所有节点。八、程序小结1、实验总结 旅游信息管理系统的程序主要分为两大方面的构思,从两个方面对程序进行操作,又通过一些关系使结构很好的结合在一起,完成了此操作系统的一些基本操作。例如有旅游景点的建立、删除、遍历和游客信息的插入语更改等,分别对应二叉树的插入,删除和遍历,还有对链表的一些基本操作。我认为操作系统得以实现的关键是在旅游景点的节点上创建了指向游客链表的指针,两种结构便产生了一定联系。通过这次数据结构课程设计,我对数据结构有了更深一步的了解,对已学过的数据结构的掌握程度在应用中通过产生问题,解决问题的过程得以很好的提升。 B篇: B-树手工题1、 题目要求 1、

24、题目内容 从空的三阶B-树开始一次插入20、30、50、52、60、68、70、10、5、80、90 然后分别删除 60、90、88、20 画出上述操作的B-树各状态。2、 运行过程 1、从空树插入 1) 、 20 2)、 20 30 3)、 30 20 30 50 20 50 4)、 30 20 50 52 5)、 30 20 50 52 60 30 52 20 50 60 6)、 30 52 20 50 60 68 7)、 30 52 20 50 60 68 70 30 52 68 20 50 60 70 52 30 68 20 50 60 70 8) 52 30 68 10 20 50

25、60 70 9) 52 30 68 5 10 20 50 60 70 52 10 30 68 5 20 50 60 70 10) 52 10 30 68 5 20 50 60 70 80 11) 52 10 30 68 5 20 50 60 70 80 90 52 10 30 68 80 5 20 50 60 70 90 2、 插入完成 52 10 30 68 80 5 20 50 60 70 90 3、依次删除要求点 1)、 52 10 30 80 5 20 50 68 70 90 2)、 52 10 30 70 5 20 50 68 80 3)、 52 10 30 70 5 20 50 6

26、8 80 4)、 10 30 52 5 20 50 68 70 30 10 52 5 20 50 68 70 5)、 30 52 5 10 50 68 70 4、最终结果 30 52 5 10 50 68 70 C篇:附加题1、 题目 1、题目要求 编程实现B-树 注:其中包括对B-树的结点的插入、删除、遍历和清楚B-树。2、 程序设计额目标 1、功能简介1) 、B-树的初 2) 、B-树的建立(结点的插入) 3) 、B-树的删除(结点的删除)4) 、B-树的遍历 (前序、中序、层次)5)、B-树的销毁 2、数据结构1) 、B-树 2)、数组 3)、队列 4)、栈(递归)三、设计思想 1、结构

27、体定义 1)、B-树节点 struct MBNode int keynum; /关键字个数域 MBNode*parent; /指向父结点的指针域 KeyType keym+1; /保存n个关键字的域,下标位置未用 MBNode*ptrm+1; /保存n+1个指向子树的指针域 ; 2)、队列的结点 typedef struct MBNode elemM; /存放树节点 int front,rear; /队头 队尾 SQ;2、功能结构图菜 单遍历插入删除销毁初始化插入前序层次中序多结点单节点 3、程序流程图 1)、查找并插入 2)、查找并删除 1)、2)、四、实现代码 1)c+源程序实现代码#in

28、clude #include #include using namespace std; typedef int KeyType; #define MAXKEY 9999#define M 20 const int m=3;typedef struct Node int keynum; /关键字个数域 struct Node *parent; /指向父结点的指针域 KeyType keym+1; /保存n个关键字的域,下标0位置未用 struct Node *ptrm+1; /保存n+1个指向子树的指针域 MNode,*MBNode; typedef struct MBNode elemM;int front,rear;SQ;void InitQ(SQ &Q) /初始化队Q.front =Q.rear =0;void EnterQ(SQ &Q,MBNode e) /进队if(Q.front =(Q.rear +1)%M)cout上溢!endl;else Q.elemQ.rear =e;Q.rea

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论