模拟旅馆管理系统的一个功能床位的分配与回收Word格式文档下载.docx
- 文档编号:22485207
- 上传时间:2023-02-04
- 格式:DOCX
- 页数:10
- 大小:344.62KB
模拟旅馆管理系统的一个功能床位的分配与回收Word格式文档下载.docx
《模拟旅馆管理系统的一个功能床位的分配与回收Word格式文档下载.docx》由会员分享,可在线阅读,更多相关《模拟旅馆管理系统的一个功能床位的分配与回收Word格式文档下载.docx(10页珍藏版)》请在冰豆网上搜索。
5
实验内容理解透彻
实验方案设计完整合理
程序总体框架设计完整
10
完成相关辅助代码
测试方案合理
实验过程
发现问题
问题的分析
15
问题的解决方法
实验报告
(20分)
内容翔实无缺漏
如实记录实验过程
撰写规整
实验总结
(10分)
实验结果的分析
按照结果对原实验方案的改进意见
实验体会
实验的收获
实验内容的发散考虑
总分
实验四模拟旅馆管理系统的一个功能——床位的分配与回收
题目:
模拟旅馆管理系统的一个功能——床位的分配与回收
1问题描述:
某旅馆有n个等级的房间,第I等级有
个房间,每个等级有
个床位(1≤I≤n)。
试模拟旅馆管理系统中床位分配和回收的功能,设计能为单个旅客分配床位,在其离店便回收床位(供下次分配)的算法。
⒉基本要求
(1)输入数据
分配时,输入旅客姓名、年龄、性别、到达日期和所需房间等级。
回收时,输入房间等级、房间号和床位号。
2)输出数据
分配成功时打印旅客姓名、年龄、到达日期、房间等级、房间号码和床位号码。
分配不成功时,如所有等级均无床位,则打印“客满”信息;
如旅客需要的等级均无空床位,则打印“是否愿意更换等级”的询问信息。
若旅客愿意更换,则重新输入有关信息,再进行分配,否则分配工作结束。
⒊实现提示
(1)数据结构
主要采用顺序结构链接结构的线性表及堆栈。
a)每个房间用一个如下所示的具有五个字段的结点(房结点)表示:
性别
房间号
现有空床数
BTOP
RLINK
其中,性别:
0表示房间为空状态
1表示房间分配给女旅客
2表示房间分配给男旅客
现有空床数:
数据在0~
之间,其中
是第i等级一个房间的床位数,当现有空床数为
时,表示房间为空;
为0时,表示房间满。
RLINK:
当房间空时,用作空房栈的连接;
当房间不空时,指向下一个房结点。
BTOP:
指向该房间的空床号栈栈顶。
一个房间对应一个顺序表示的空床号栈。
栈的容量为
,栈中存放空床号。
分配时,从栈顶取出空床号,栈顶下移(BTOP=BTOP+1);
回收时,栈顶上移(BTOP=BTOP-1),将回收的空床号填入栈顶。
每一个等级中的空房间构成一个空房栈;
已住旅客的房间构成一个链栈(简称房链),其头结点结构如下:
可分配女床位总数
可分配男床位总数
TTOP
其中:
:
第i等级中房间总数
第i等级中每个房间的床位数
可分配男、女床位的总数的初值等于
*
,因为开始时所有房间和床位既可以分配给男旅客,也可以分配给女旅客。
当在房链中分配一个床位给男(女)旅客,床位总数应减1;
当从空房栈中取出一个房间作为男(女)旅客房间时,则可分配女(男)床位总数应减
,当回收一个男(女)床位时,则可分配男(女)床位总数应加1;
当回收一个男(女)空房至空房栈时,则可分配女(男)床位总数应加
。
TTOP:
指向本级空房栈栈顶,当无空房间时,TTOP=^(NIL)。
指向本级房链第一个顶点,当房链为空时,RLINK=^(NIL)
顺序表s=(
),其中,
顺序存放第1~n等级房间的头结点;
存放内容如下所示:
全店可分配女床总数
^
初始时,全店可分配男、女床总数相同,均为
,在分配或回收时,对各等级可分配男(女)床位总数处理的同时也要对全店可分配男(女)床总数作相应处理,当全店可分配男(女)床总数等于零时,表示客满。
(2)需求分析
经过分析,程序要有以下几个功能:
a.程序启动的时候应该能够对旅馆的信息进行初始化,并且可以让不同的进行手动初始化;
b.当客户到来的时候,可以登录客户的信息,并且根据旅馆的情况和客
户的要求进行分配床位;
c.当客户结账的时候,可以打印其账单,并且将床位回收;
d.在进行输入信息的时候,应该有检查错误的功能,防止输入的信息超出正常范围.
4、概要设计
功能模块的划分
功能模块的描述:
1.信息的初始化:
应该包括两种初始化,第一种是每次打开程序的时候,自动完成对旅馆信息的初始化。
第二种是由用户输入旅馆的信息,完成旅馆信息的初始化。
2.显示模块.显示模块是人机交互的必要模块,用于显示主菜单、旅馆的当前住宿情况、
床位分配情况、账单等等,方便用户进行下一步操作。
3.客户登记及床位分配模块:
用来登记客户的信息以及床位的分配。
4.客户退房及床位回收模块:
用来登记退房客户的信息以及床位的回收。
5.保存信息模块:
用来保存旅馆的相关信息,包括手动初始化之后的客房信息,以及退出程序之前的保存工作。
6.退出:
退出程序。
4.源程序代码:
#include"
"
#include<
iostream>
usingnamespacestd;
#include<
>
ex=-1;
ge=0;
ay=0;
p->
person[k].month=0;
person[k].year=0;
ednumber=0;
p->
person[k].day=0;
person[k].sex=-1;
ednumber=0;
ame=name;
ge=age;
p->
person[j].sex=sex;
person[j].year=year;
person[j].month=month;
person[j].day=day;
person[j].bednumber=j+1;
ednumber==bednumber){ame="
;
p->
person[j].sex=-1;
person[j].year=0;
person[j].month=0;
person[j].day=0;
person[j].bednumber=0;
bed[j]=0;
ednumber!
=0){
printf("
\n房间等级:
%d,房间号:
%d,"
p->
roomgrade,p->
roomnumber);
顾客姓名:
);
cout<
<
p->
person[k].name;
顾客性别:
%d该房间内已住人数:
%d,房间到期日期:
%d年,%d月,%d日,"
person[k].sex,p->
peoplein,p->
person[k].year,p->
person[k].month,p->
person[k].day);
该房间已住人的床号为:
for(i=0;
i<
M;
i++)
if(p->
bed[i]==1)
printf("
i+1);
}
}
p=p->
next;
序截图:
6.实验总结
(1)本次课程设计的题目是模拟旅馆的一个功能——床位的分配与回收。
我采用的是链表和栈的结构形式进行编程,基本完成题目的要求,既对链表和栈的相关知识有了更加深刻的理解,而且又熟练了c语言编程。
(2)我们定义了一个顺序表来存储每一级房间的头结点。
然后义了三个结构体,房间节点的结构体,床位节点的结构体,客户节点的结构体,分别用来存放房间、床位、客户的相关信息。
然后用了链式存储结构的栈结构,分别为空房栈、已住房栈、空床位栈、已住床位栈。
(3)本次实验涉及到的主要是链表的和栈的运算,包括有链表的建立,插入,删除,栈主要是进栈,出栈,栈节点的查找等,进一步加深了对数据结构的了解。
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 模拟 旅馆 管理 系统 一个 功能 床位 分配 回收
![提示](https://static.bdocx.com/images/bang_tan.gif)