- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
理發馆模拟系统实验报告
一、问题描述
理发馆一天的工作过程如下:
理发馆有N把理发椅,可同时为N位顾客进行理发。
理发师分三个等级(一级、二级、三级),对应不同的服务收费。
当顾客进门时,需选择某级别理发师,只要该级别的理发师有空椅,则可立即坐下理发,否则需排队等候。
一旦该级别的理发师有顾客理发完离去,排在队头的顾客便可开始理发。
若理发馆每天连续营业T分钟,求
一天内顾客在理发馆内的平均逗留时间;
顾客排队等候理发的队列长度平均值;
营业时间到点后仍需完成服务的收尾工作时间;
统计每天的营业额;
统计每天不同级别理发师的创收。
[ 基本要求 ] :
模拟理发馆一天的工作过程:必须采用事件驱动的离散模型(参考教科书3.5节离散事件模拟p65);
每个顾客到达和下一顾客到达时间的间隔应是随机的;
理发师编号、理发师级别和每天的营业时间由用户输入;
某顾客挑选某一个级别的理发师而不得时,选第一个队列排队等待 ;
每个顾客进门时将生成三个随机数:
durtime:进门顾客理发所需服务时间(简称:理发时间);
intertime:下一顾客将到达的时间间隔(简称:间隔时间);
select:服务选项 。
服务收费:应包含服务时间和理发师级别两个因素。
除了输出统计的数据外,还需要显示理发馆的状态,可以采用文本方式(横向显示每张椅编号、理发师级别。纵向表示等待该理发师理发的排队长度)。
[ 测试数据 ] :用户输入每位理发师编号、级别号和营业的时间,结合随机数进行测试。
[ 实现提示 ]
顾客进门和出门这两个时刻发生的事情称“事件”,按事件的先后次序逐个处理事件的工作方式称“事件驱动模拟”。离散事件驱动模型的特点是只关注和刻画事物的状态变化(即事件),不关心变化的过渡过程。模型靠每一个事件引发其它事件的方式来维持运转。每个事件都有发生时间,模型的运转实际就是按事件发生时间顺序逐个处理事件,处理将产生新的事件。因此,建模的关键就是全面分析事物的主要特点,抽象出几种能反映本质的事件和它们之间的驱动关系。系统时间就是当前事件的事件发生时间,它不是等间隔变化而是跳跃变化的。
数据结构:本题设计两个抽象数据类型
队列抽象数据类型:登录排队等候理发的顾客情况。每个元素应包括顾客进门时刻、理发师级别、理发所需时间。N把椅子对应N个队列。
事件链表抽象数据类型:登录顾客进门事件、出门事件。每个事件应包括事件类型(进门事件类型为0,出门事件类型按N把椅子所排队列分为为1、2、...N)和事件发生的时刻occurtime。为便于按事件发生先后顺序逐一处理事件,事件表应按“时刻”有序。
3) 对理发椅需要进行编号,使不同级别的理发师与编号的理发椅相对应。
二、系统简介
2.1开发环境:Codeblocks 12.11;
2.2利用基础数据结构来完成对理发馆经营状况的模拟
2.3 整个系统共分为3个文件,分别为主文件BarberShop.exe、配置文件config.csv以及程序运行后产生的统计信息文件statistics.txt
三、总体设计(模块框架图)
使用说明
使用前请先使用excel表格配置config.csv,根据每个参数的填写要求填写
填写完成后,打开主文件BarberShop.exe,即可开始模拟理发馆经营状况
模拟完成后,系统会生成statistics.txt文件,即理发馆经营状况的文件
源程序
##includecstdio
#includecstdlib
#includectime
#includequeue
using namespace std;
int nowTime,cusnum[4];
char barberName[4][100][10];
struct settings
{
int openTime;
int endTime;
int closeTime;
int numBaber[4];
int fee[4];
int addFee[4];
int interTimeMo;
int durTimeMo;
int customNum;
}setting;
struct answers
{
int totalTime;
int totalLenth;
int customNum;
int totalEarn;
int closeTime;
int baberEarn[4][100];
}answer;
typedef struct
{
int time;
int durTime;
int level;
}event;
typedef struct
{
char
您可能关注的文档
最近下载
- 上海华谊(集团)公司行测笔试题库2022.pdf
- 专题03 阅读填空20篇(中考真题+各区名校模拟)2023年广州中考英语冲刺专项训练(解析版).docx VIP
- 产品结构设计课作业.doc VIP
- 临床药物治疗学模拟考试题+答案.docx VIP
- 临床药物治疗学考试题与答案.docx VIP
- 霸碗 盖码饭 智能炒菜机器人 品牌手册(2023Q4版).pdf
- 临床药物治疗学考试题+答案.docx VIP
- 人教版小学三年级体育教案全集全册.doc VIP
- 2011-2016年淮北师范大学《分析化学》考研真题汇总.pdf VIP
- 2011-2016年淮北师范大学《无机化学》考研真题汇总.pdf VIP
文档评论(0)