




版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
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 27 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<iostream>#include<stdlib.h>#include<string>#include<iomanip>using namespace std;#define MAX 50#define SIZE 12typedef struct tourist char nameSIZE; int id; char sex5; struct tourist *next;Trist,*l
8、inklist;typedef struct Tree_Place int code; /旅游地区号 char areaSIZE; /旅游地名称 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 &t
9、ree);void Destory(TPlace &tree);void Init_L(linklist &head) head=NULL;void Insert_L (TPlace &tree,TPlace &t,linklist &head) linklist tr; char c; int i=1,co,id; while(t->count<6&&i=1) cout<<"请输入你的身份证号:"<<endl; cin>>id; tr=(linklist)malloc(
10、sizeof(Trist); tr->id =id; cout<<"输入姓名,性别:"<<endl; cin>>tr->name>>tr->sex; tr->next=head; head=tr;t->count+; cout<<"继续报名请按1,按0退出!"<<endl; cin>>i; if(t->count>=6) cout<<"此旅游地人数已满,按'y'选择其他旅游地,其他键退出!&q
11、uot;<<endl;cin>>c; if(c='y'|c='Y') cout<<"请重新输入区号"<<endl;cin>>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
12、) /在二叉排序树中插入一个新结点 if (tree=NULL) tree=p; else if(p->code<tree->code) Insert_T(tree->lchild,p); else if(p->code>tree->code) Insert_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->code>co
13、) p=p->lchild ; else p=p->rchild ; if(!p) cout<<"此旅游地点还未存在!"<<endl;system("pause");Tour_2(tree); else if(p->count>=6) cout<<"此旅游地人数已满,按'y'选择其他旅游地,其他键退出!"<<endl;cin>>c; if(c='y'|c='Y') cout<<"请重
14、新输入区号"<<endl;cin>>code;Search_T(tree,code);else Tour_2(tree); else cout<<"可以报名"<<endl;Insert_L(tree,p, p->list);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) b
15、reak; parent=p; if(p->code>co) p=p->lchild; else p=p->rchild; if(p=NULL) /不存在该树节点 return t; if(p->lchild=NULL) /无左子树,右子树可有可无 if(parent=NULL) t=p->rchild; else if(parent->lchild=p) parent->lchild=p->rchild; else parent->rchild=p->rchild; Delet_L (p->list); free(p);
16、 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 &tree) char c; int n; TPlace p; cout<<"请输入
17、插入地点个数:"<<endl; cin>>n; cout<<"依次输入各个旅游地点的区号和地名:"<<endl; for(int i=0;i<n;i+) p=(TPlace)malloc(sizeof(Place); cout<<"请输入第"<<i+1<<"个地点:"<<endl; cin>>p->code>>p->area ; p->lchild =p->rchild =NU
18、LL; p->list=NULL; p->count =0; Insert_T(tree,p); cout<<"输入完成,输入y或者Y继续操作,其他键退出!" cin>>c; if(c='y'|c='Y') Fun1(tree); else system("cls");Tour_1(tree);void Fun2(TPlace &tree,int x) int top=0; TPlace p,sMAX; p=tree; while(p|top>0) while(p) sto
19、p+=p; p=p->lchild; if(top>0) p=s-top;cout<<setw(8)<<"区号:"<<p->code<<setw(10)<<"地名:"<<p->area<<setw(10)<<"人数:"<<p->count<<endl; p=p->rchild; if(tree=NULL)cout<<"还未录入旅游地!请稍后查询!"&
20、lt;<endl; cout<<"按任意键返回上一级菜单!"<<endl; system("pause");if(x=1)Tour_1(tree);if(x=2) Tour_2(tree);void Fun3(TPlace &tree,int x) int n1=0,n2=0; char c; int top=0; int elemMAX; TPlace p,sMAX; p=tree; while(p|top>0) while(p) stop+=p; p=p->lchild; if(top>0) p
21、=s-top; if(p->count<3&&x=1) cout<<setw(8)<<"区号:"<<p->code<<setw(10)<<"地名:"<<p->area<<setw(10)<<"人数:"<<p->count<<endl;elemn1=p->code ;n1+; if(p->count<6&&x=2) cout<<
22、setw(8)<<"区号:"<<p->code<<setw(10)<<"地名:"<<p->area<<setw(10)<<"人数:"<<p->count<<endl;n2+; p=p->rchild; if(x=1)cout<<"一共有"<<n1<<"各旅游景点人数少于三个"<<endl;cout<<&qu
23、ot;删除旅游地请输入D或者d,其他键返回菜单!"<<endl;cin>>c; if(c='d'|c='D') for(int i=0;i<n1;i+) Delete_T(tree,elemi);cout<<"删除完成!"<<endl; system("pause");Tour_1(tree); if(x=2)cout<<"一共有"<<n2<<"个旅游景点仍可报名"<<en
24、dl;cout<<"按任意键返回上一级菜单!"<<endl;system("pause");Tour_2(tree); void Fun4(TPlace &tree) int co,id;TPlace p; linklist l,pre; p=tree; cout<<"输入要退出旅游地的区号和自己的身份证号:"<<endl; cin>>co>>id; while(p&&p->code!=co ) if(p->code>co
25、) p=p->lchild ; else p=p->rchild ; if(!p) cout<<"此旅游地点还未存在!"<<endl;system("pause");Tour_2(tree); else l=p->list;pre=l; while(l->id!=id) pre=l; l=l->next; pre->next=l->next;free(l);p->count-;cout<<"输入要报名的地点区号:"<<endl;cin>
26、;>co;Search_T(tree,co); void Mainlist(TPlace &tree) system("cls"); cout<<" *"<<endl<<endl; cout<<" 欢迎登陆旅游购票系统"<<endl; cout<<" 请选择登录身份:"<<endl; cout<<" 1、旅游公司管理人员"<<endl; cout<<"
27、2、游客"<<endl; cout<<" 3、退出 程序"<<endl; cout<<" *"<<endl<<endl; int n,key,i=1; cin>>n; switch(n) case 3: Destory(tree);exit(0); case 1: docout<<"请输入登陆密码:"cin>>key;i+; while(key!=12345&&i<=3); if(key=1234
28、5) 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<<" *"<<endl<<endl; cout<<&qu
29、ot; 1、输入旅游地点 "<<endl; cout<<" 2、查询各旅游地游客人数"<<endl; cout<<" 3、显示不足三人的旅游地"<<endl; cout<<" 4、退出"<<endl; cout<<" *"<<endl<<endl; cin>>n; switch(n) case 1: Fun1(tree);break; case 2: Fun2(tree,1)
30、;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<<" *"<<endl<<endl; cout<<&
31、quot; 1、输入旅游地区号 "<<endl; cout<<" 2、显示所有旅游地"<<endl; cout<<" 3、查询可报名地"<<endl; cout<<" 4、修改旅游地点"<<endl; cout<<" 5、退出"<<endl; cout<<" *"<<endl<<endl; cin>>n; switch(n) cas
32、e 1: cout<<"请输入区号:"<<endl;cin>>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); /
33、销毁二叉树void Destory(TPlace &tree)if(!tree) cout<<"此树已空!"<<endl;system("pause"); exit(0);if(tree&&tree->lchild)Destory(tree->lchild);if(tree&&tree->rchild)Destory(tree->rchild);cout<<setw(5)<<tree->code<<setw(5)<<tree->area<<endl; Delet_L (tree->list);free(tree);void main() TPlace T=NULL; Mainlist(T);六、调试分析及测试结果 1、运行结果截图七、附录 1、补充说明 #include<
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 学校介护实训室设备采购 投标方案(技术方案)
- 体育馆土石方运输平整协议
- 医疗器械操作规范与标准作业指导书
- 环保理念与低碳生活实践方法作业指导书
- 三农人才培养及实施方案指导书
- 新能源汽车充电红灯
- 新能源汽车充电桩难题
- 品牌管理与推广操作手册
- 商家自行配送怎么查物流
- 施工建筑设计说明
- 2025年医保知识考试题库及答案-医保定点医疗机构管理流程详解试题
- 2025年铁岭卫生职业学院单招职业倾向性测试题库学生专用
- The uses of infinitives 动词不定式(教学设计)-2024-2025学年人教新目标Go For It!英语八年级上册
- (一模)2025届安徽省“江南十校”高三联考地理试卷(含官方答案)
- 数学-2025届安徽省江南十校联考试题和解析
- 普通高中学生综合素质评价自我陈述报告
- 《展示设计》课件-第一章 展示设计概述
- 介入手术术中安全护理措施
- 投资银行学第4版- 课件汇 马晓军 第1-4章 投资银行概述-上市公司再融资
- 学生常见传染病的预防
- 2025年月度工作日历含农历节假日电子表格版
评论
0/150
提交评论