


全文预览已结束
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
#include #include #include#include#include using namespace std;/初始定义const int maxfloor=14;/最高楼层clock_t tick;/获取系统当前运行时间/基本数据结构及其功能函数与类的声明模块struct Condition/状态类float time;/该状态下持续的时间;int sympol;/状态的开关标志符 ;struct LiftCondition/电梯状态类Condition rest;Condition up;Condition down;struct Lift/电梯类int paNum;/乘客数int presentFloor;/当前楼层LiftCondition liftCon;/电梯状态int lightmaxfloor+1;/目标层数数组int goalNummaxfloor+1;/要去每层的人数float workTime;float workTimePre;struct Passenger/乘客类int presentFloor;/乘客当前楼层int goalFloor;/目标层int tolerateTime;/容忍时间float initTime;/建立时间Passenger *next;Passenger *pre;struct QuePassenger *front;/队列头指针Passenger *rear;/队列尾指针;Passenger *mid;int length;void initQue(Que &q)/队列的建立函数q.front=(Passenger *)malloc(100*sizeof(Passenger);q.rear =q.front;q.length =0;void addQue(Que &q,Passenger &p)/队列成员增加函数q.rear -next =&p;p.pre =q.rear ;q.rear =q.rear -next ;q.length +;int queLength(Que &q)/队列的长度函数return q.length ;void outQue(Que &q)/队首出队函数if(queLength(q)1)q.mid=q.front -next ;q.front -next =q.mid-next ;q.mid-next -pre =q.front;q.mid-next =NULL;q.mid-pre =NULL;q.length -;elseq.rear -pre =NULL;q.rear=q.front ;q.rear -next =NULL;q.length =0;struct Floor/楼层类Que goUp;Que goDown;int callUp;int callDown;int totalNum;/全局变量int passNum=0;Floor fl15;Passenger pa100;int i=0;/循环计数器;/函数模块extern void addPassenger(Passenger &p);extern void getInUp(Lift &l);extern void getInDown(Lift &l);extern void liftUp(Lift &l);extern void getOut(Lift &l);extern int ergodicFloorUp(Lift &l);extern int ergodicFloorDown(Lift &l);extern void UserFace(Lift &l);void initFloor()/初始化每个楼层的函数for(i=1;i15;i+)initQue(fli.goDown );initQue(fli.goUp );fli.totalNum =0;fli.callDown =0;fli.callUp =0;void initLift(Lift &l)/初始化电梯l.liftCon.rest.sympol =1;l.liftCon .up.sympol =0;l.liftCon .down .sympol =0;l.liftCon.rest.time =0;l.liftCon .up.time =0;l.liftCon .down .time =0;for(i=1;i15;i+)l.lighti=0;l.goalNum i=0;l.paNum=0;l.presentFloor=1;tick=clock();l.workTime=l.workTimePre=(float)tick/CLK_TCK;void addPassenger(Passenger &p)/创建一名乘客cout该乘客所在楼层p.presentFloor;if(p.presentFloor 14)cout楼层越界endl;cout重新输入p.presentFloor;cout该乘客要去的楼层p.goalFloor ;if(p.goalFloor 14)cout楼层越界endl;cout重新输入p.goalFloor ;cout该乘客的容忍时间p.tolerateTime ;if(p.goalFloor p.presentFloor )flp.presentFloor .callUp =1;addQue(flp.presentFloor .goUp ,p);elseflp.presentFloor .callDown =1;addQue(flp.presentFloor .goDown ,p);flp.presentFloor .totalNum +;tick=clock();p.initTime =(float)tick/CLK_TCK;passNum+;void getInUp(Lift &l)/进入电梯往上行驶函数l.liftCon .rest.sympol =1;l.liftCon .down .sympol =0;l.liftCon .up .sympol =0;fll.presentFloor .callUp =0;Sleep(500);cout电梯门打开endl;Sleep(500);cout乘客正在进入电梯endl;Sleep(500);cout乘客正在进入电梯endl;Sleep(500);cout乘客正在进入电梯endl;Sleep(500);cout乘客正在进入电梯endl;Sleep(500);cout乘客正在进入电梯endl;Sleep(500);cout乘客正在进入电梯endl;tick=clock();l.workTime =(float)tick/CLK_TCK;while(l.paNumnext -initTime)next -tolerateTime )l.lightfll.presentFloor.goUp .front-next -goalFloor=1;l.goalNumfll.presentFloor.goUp .front-next -goalFloor+;outQue(fll.presentFloor .goUp );l.paNum +;elsecout有一名乘客因等待时间过长已经离开endl;outQue(fll.presentFloor .goUp );if(queLength(fll.presentFloor .goUp )=0)cout乘客进入电梯完毕,电梯关门endl;break;if(l.paNum =2)cout电梯已满员,电梯关门endl;void getInDown(Lift &l)/进入电梯往下行驶函数l.liftCon .rest.sympol =1;l.liftCon .down .sympol =0;l.liftCon .up .sympol =0;fll.presentFloor .callDown=0;Sleep(500);cout电梯门打开endl;Sleep(500);cout乘客正在进入电梯endl;Sleep(500);cout乘客正在进入电梯endl;Sleep(500);cout乘客正在进入电梯endl;Sleep(500);cout乘客正在进入电梯endl;Sleep(500);cout乘客正在进入电梯endl;Sleep(500);cout乘客正在进入电梯endl;tick=clock();l.workTime =(float)tick/CLK_TCK;while(l.paNumnext -initTime)next -tolerateTime )l.lightfll.presentFloor.goDown .front-next -goalFloor=1;l.goalNumfll.presentFloor.goDown .front-next -goalFloor+;outQue(fll.presentFloor .goDown );l.paNum +;elsecout有一名乘客因等待时间过长已经离开endl;outQue(fll.presentFloor .goDown );if(queLength(fll.presentFloor .goDown )=0)cout乘客进入电梯完毕,电梯关门endl;break;if(l.paNum =12)cout电梯已满员,电梯关门endl;void getOut(Lift &l)l.liftCon .rest.sympol =1;l.liftCon .down .sympol =0;l.liftCon .up .sympol =0;Sleep(500);cout该楼层电梯内正有乘客出电梯endl;Sleep(500);cout该楼层电梯内正有乘客出电梯endl;Sleep(500);cout该楼层电梯内正有乘客出电梯endl;Sleep(500);cout该楼层电梯内正有乘客出电梯endl;Sleep(500);cout该楼层电梯内正有乘客出电梯endl;Sleep(500);cout该楼层电梯内正有乘客出电梯endl;l.light l.presentFloor =0;l.paNum -=l.goalNum l.presentFloor ;l.goalNum l.presentFloor =0; cout电梯内现在有 l.paNum 人endl;int ergodicFloorUp(Lift &l)/电梯内人数为0时遍历函数if(l.liftCon .rest.sympol ) =1)for(i=l.presentFloor;i=1;i-)if(fli.callDown =1|fli.callUp =1)return(1);return(0);void liftDown(Lift &l)l.liftCon .rest.sympol =0;l.liftCon .down .sympol =1;l.liftCon .up .sympol =0;Sleep(500);cout电梯正在下降endl;cout电梯在 l.presentFloor 层endl;Sleep(500);cout电梯正在下降endl;cout电梯在 l.presentFloor 层endl;Sleep(500);cout电梯正在下降endl;cout电梯在 l.presentFloor 层endl;Sleep(500);cout电梯正在下降endl;cout电梯在 l.presentFloor 层endl;Sleep(500);cout电梯正在下降endl;cout电梯在 l.presentFloor 层endl;Sleep(500);l.presentFloor -;cout电梯正在下降endl;cout电梯在 l.presentFloor 层endl;l.liftCon .down.time +=3;cout是否有新的乘客出现?是1否0j;if(j!=0)system(cls);addPassenger(papassNum);if(l.light l.presentFloor !=1&fll.presentFloor .callDown !=1&fll.presentFloor.callUp !=1)cout电梯内无乘客到该层,且该层没有呼叫电梯向下,电梯继续下降0)cout电梯门已经关闭,电梯继续下降endl;liftDown(l);elseif(ergodicFloorDown(l)=1)liftDown(l);elseif(ergodicFloorUp(l)=1)liftUp(l);elsewhile(1)cout现在无人使用电梯,电梯静止在 l.presentFloor 层endl;cout是否返回主菜单?是1否0k;if(k!=0)UserFace(l);cout是否有新的乘客出现?是1否0j;if(j!=0)system(cls);addPassenger(papassNum);if(papassNum-1.presentFloor l.presentFloor )liftUp(l);else if(papassNum-1.presentFloor l.presentFloor )getInUp(l);liftUp(l);elsegetInDown(l);liftDown(l);break;elsecontinue;if(l.light l.presentFloor !=1&fll.presentFloor .callDown =1&l.paNum 12)cout该层有人呼叫向下0)cout电梯门已经关闭,电梯继续下降endl;liftDown(l);elseif(ergodicFloorDown(l)=1)liftDown(l);elseif(ergodicFloorUp(l)=1)liftUp(l);elsewhile(1)cout现在无人使用电梯,电梯静止在 l.presentFloor 层endl;cout是否返回主菜单?是1否0k;if(k!=0)UserFace(l);cout是否有新的乘客出现?是1否0j;if(j!=0)system(cls);addPassenger(papassNum);if(papassNum-1.presentFloor l.presentFloor )liftUp(l);else if(papassNum-1.presentFloor l.presentFloor )getInUp(l);liftUp(l);elsegetInDown(l);liftDown(l);break;elsecontinue;if(l.light l.presentFloor =1&fll.presentFloor .callDown =1)cout该层有人呼叫向下且有电梯出电梯0)cout电梯门已经关闭,电梯继续下降endl;liftDown(l);elseif(ergodicFloorDown(l)=1)liftDown(l);elseif(ergodicFloorUp(l)=1)liftUp(l);elsewhile(1)cout现在无人使用电梯,电梯静止在 l.presentFloor 层endl;cout是否返回主菜单?是1否0k;if(k!=0)UserFace(l);cout是否有新的乘客出现?是1否0j;if(j!=0)system(cls);addPassenger(papassNum);if(papassNum-1.presentFloor l.presentFloor )liftUp(l);else if(papassNum-1.presentFloor l.presentFloor ) getInUp(l);liftUp(l);elsegetInDown(l);liftDown(l);break;elsecontinue;if(fll.presentFloor .callUp =1)if(l.paNum =0)cout该层有人呼叫向上0)cout电梯门已经关闭,电梯上升endl;liftUp(l);elseif(ergodicFloorDown(l)=1)liftDown(l);elseif(ergodicFloorUp(l)=1)liftUp(l);elsewhile(1)cout现在无人使用电梯,电梯静止在 l.presentFloor 层endl;cout是否返回主菜单?是1否0k;if(k!=0)UserFace(l);cout是否有新的乘客出现?是1否0j;if(j!=0)system(cls);addPassenger(papassNum);if(papassNum-1.presentFloor l.presentFloor )liftUp(l);else if(papassNum-1.presentFloor l.presentFloor )getInUp(l);liftUp(l);elsegetInDown(l);liftDown(l);break;elsecontinue;void liftUp(Lift &l)if(fl1.callUp=1)getInUp(l);l.liftCon .rest.sympol =0;l.liftCon .down .sympol =0; l.liftCon .up .sympol =1;Sleep(500);cout电梯正在上升endl;cout电梯在 l.presentFloor 层endl;Sleep(500);cout电梯正在上升endl;cout电梯在 l.presentFloor 层endl;Sleep(500);cout电梯正在上升endl;cout电梯在 l.presentFloor 层endl;Sleep(500);cout电梯正在上升endl;cout电梯在 l.presentFloor 层endl;Sleep(500);cout电梯正在上升endl;cout电梯在 l.presentFloor 层endl;Sleep(500);l.presentFloor +;cout电梯正在上升endl;cout电梯在 l.presentFloor 层endl;l.liftCon .up.time +=3;cout是否有新的乘客出现?是1否0j;if(j!=0)system(cls);addPassenger(papassNum);if(l.light l.presentFloor !=1&fll.presentFloor .callUp !=1&fll.presentFloor.callDown !=1 )cout电梯内无乘客到该层,且该层没有呼叫电梯向上,电梯继续上升endl;liftUp(l);if(l.light l.presentFloor =1&fll.presentFloor .callUp !=1)getOut(l);if(l.paNum !=0)l.liftCon .rest.sympol =0;l.liftCon .down .sympol =1;l.liftCon .up .sympol =0;cout电梯门已经关闭,电梯继续上升endl;liftUp(l);elseif(ergodicFloorUp(l)=1)liftUp(l);elseif(ergodicFloorDown(l)=1)liftDown(l);elsewhile(1)cout现在无人使用电梯,电梯静止在 l.presentFloor 层endl;cout是否返回主菜单?是1否0k;if(k!=0)UserFace(l);cout是否有新的乘客出现?是1否0j;if(j!=0)system(cls);addPassenger(papassNum);if(papassNum-1.presentFloor l.presentFloor )liftUp(l);else if(papassNum-1.presentFloor l.presentFloor )getInUp(l);liftUp(l);elsegetInDown(l);liftDown(l);elsecontinue;if(l.light l.presentFloor !=1&fll.presentFloor .callUp =1&l.paNum 12)cout该层有人呼叫向上endl;getInUp(l);if(l.paNum !=0)l.liftCon .rest.sympol =0;l.liftCon .down .sympol =1;l.liftCon .up .sympol =0;cout电梯门已经关闭,电梯继续上升endl;liftUp(l);elseif(ergodicFloorUp(l)=1)liftUp(l);elseif(ergodicFloorDown(l)=1)liftDown(l);elsewhile(1)cout现在无人使用电梯,电梯静止在 l.presentFloor 层endl;cout是否返回主菜单?是1否0k;if(k!=0)UserFace(l);cout是否有新的乘客出现?是1否0j;if(j!=0)system(cls);addPassenger(papassNum);if(papassNum-1.presentFloor l.presentFloor )liftUp(l);else if(papassNum-1.presentFloor l.presentFloor )getInUp(l);liftUp(l);elsegetInDown(l);liftDown(l);elsecontinue;if(l.light l.presentFloor =1&fll.presentFloor .callUp =1)cout该层有人呼叫向上且有乘客出电梯cout;getOut(l);getInUp(l);if(l.paNum !=0)cout电梯门已经关闭,电梯继续上升endl;liftUp(l);elseif(ergodicFloorUp(l)=1)liftUp(l);elseif(ergodicFloorDown(l)=1)liftDown(l);elsewhile(1)cout现在无人使用电梯,电梯静止在 l.presentFloor 层endl;cout是否返回主菜单?是1否0k;if(k!=0)UserFace(l);cout是否有新的乘客出现?是1否0j;if(j!=0)system(cls);addPassenger(papassNum);if(papassNum-1.presentFloor l.presentFloor )liftUp(l);else if(papassNum-1.presentFloor l.presentFloor )getInUp(l);liftUp(l);elsegetInDown(l);liftDown(l);elsecontinue;if(fll.presentFloor .callDown =1)if(l.paNum =0)cout该
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 塑料厂办公设备管理规范制度
- 化肥厂采购设备更新规章
- 2025年小学租房合同范本
- 粤教版高 一 信息技术 必修一教学设计:1.1 信息及其特征
- 3.3《天气系统-气旋和反气旋》教学设计-2024-2025学年湘教版(2019)高中地理选择性必修一
- 本册综合教学设计-2025-2026学年小学信息技术(信息科技)六年级下册青岛版(六三制)
- Unit 4 Perseverance and Success Exploring and Using 教学设计-2024-2025学年高中英语重大版(2019)选择性必修第二册
- 2025江苏苏州常熟市基层公共服务岗位招聘低收入家庭、困难家庭和就业困难高校毕业生25人考试备考试题及答案解析
- 矿山企业工伤赔偿项目和赔偿标准合同
- 建筑施工模板及脚手架安装拆除一体化承包合同
- 2025年浙能集团甘肃有限公司新能源项目(第二批)招聘17人笔试历年参考题库附带答案详解
- 高压氧舱培训课件
- 高二物理第一次月考卷【测试范围:第11~12章】(考试版A3)
- 2025年大一上学期java期末考试题及答案
- 法国方言政策的沿袭与变革
- (2025年标准)教师定岗协议书
- 8 回忆鲁迅先生(课件)语文统编版2024八年级上册
- 学校学生欺凌治理委员会成员及工作职责、实施方案范文
- 2025年蜀道投资集团有限责任公司招聘笔试备考题库附答案详解(达标题)
- 美术基础 课件 第1、2章 美术简介;素描
- 2025年廉价航空行业研究报告及未来发展趋势预测
评论
0/150
提交评论