java多线程电梯调度_面向对象之多线程(可捎带电梯调度)

面向对象之多线程(可捎带电梯调度)

1. 题目重述

​本题完成的任务为多部多线程可捎带调度电梯的模拟,电梯系统具有的功能为:上下行、开关门、新增一部可以使用的电梯,电梯系统在某一层开关门时间内可以上下乘客。电梯系统可以采用任一的调度策略,只要保证在一定时间内将所有乘客送至目的地即可。

​本题采用的是目的选层电梯,在电梯的每层入口,都有一个输入装置,让每个乘客输入自己的目的楼层,所以一个电梯请求除了人员id,还有这个人的出发楼层和目的楼层。

​电梯类型分为A型、B型、C型,在新增电梯时指定类型。初始有3部电梯,编号分别为A、B、C,新增电梯编号为X1、X2、……、Xn。三类电梯的开关门时间都分别为0.2s。

三类电梯的可停靠楼层、上升或下降一层时间、最大载客量

A型:-3, -2, -1, 1, 15~20 0.4s 6人

B型:-2, -1, 1, 2, 4~15 0.5s 7人

C型: 1, 3, 5, 7, 9, 11, 13, 15 0.6s 8人

样例输入

[1.0]X1-ADD-ELEVATOR-A

[2.0]1-FROM--3-TO-2

样例输出

[2.4060]ARRIVE--1-X1

[2.8070]ARRIVE--2-X1

[3.2070]ARRIVE--3-X1

[3.2080]OPEN--3-X1

[3.2080]IN-1--3-X1

[3.6080]CLOSE--3-X1

[4.0090]ARRIVE--2-X1

[4.4100]ARRIVE--1-X1

[4.8100]ARRIVE-1-X1

[4.8100]OPEN-1-X1

[4.8100]OPEN-1-B

[4.8110]OUT-1-1-X1

[4.8110]IN-1-1-B

[5.2120]CLOSE-1-B

[5.2120]CLOSE-1-X1

[5.7120]ARRIVE-2-B

[5.7120]OPEN-2-B

[5.7130]OUT-1-2-B

[6.1130]CLOSE-2-B

2. 电梯调度策略

2.1 ALS调度策略

ALS电梯的请求分为主请求和被捎带请求

主请求选择规则:

如果电梯中没有乘客,将请求队列中到达时间最早的请求作为主请求

如果电梯中有乘客,将其中到达时间最早的乘客请求作为主请求

被捎带请求选择规则:

电梯的主请求存在,即主请求到该请求进入电梯时尚未完成

该请求到达请求队列的时间小于等于电梯到达该请求出发楼层关门的截止时间

电梯的运行方向和该请求的目标方向一致。即电梯主请求的目标楼层和被捎带请求的目标楼

层,两者在当前楼层的同一侧。<

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
面向对象方法和面向对象程序设计语言,实现满足下述要求的一个高层建筑电梯活动 仿真程序。 问题域概述 某国际展览中心共 40 层,设有载客电梯10 部(用E0~E9 标识)。 限定条件 (1) 电梯的运行规则是: E0、E1:可到达每层。 E2、E3:可到达1、25~40 层。 E4、E5:可到达1~25 层。 E6、E7:可到达1、2~40 层中的偶数层。 E8、E9:可到达1~39 层中的奇数层。 (2) 每部电梯的最大乘员量均为K 人(K 值可以根据仿真情况在10~18 人之间确定)。 (3) 仿真开始时,各电梯随机地处于其符合运行规则的任意一层,为空梯。 (4) 仿真开始后,有N 人(0<N<1000)在M 分钟(0<M<10)内随机地到达该国际 展览中心的1 层,开始乘梯活动。 (5) 每位乘客初次所要到达的楼层是随机的,令其在合适的电梯处等待电梯到来。 (6) 每位乘客乘坐合适的电梯到达指定楼层后,随机地停留10-120 秒后,再随机 地去往另一楼层,依此类推,当每人乘坐过L 次(每人的L 值不同,在产生乘客时随机地 在1~10 次之间确定)电梯后,第L+1 次为下至底层并结束乘梯行为。到所有乘客结束乘梯 行为时,本次仿真结束。 (7) 电梯运行速度为S 秒/层(S 值可以根据仿真情况在1~5 之间确定),每人上下时 间为T 秒(T 值可以根据仿真情况在2~10 之间确定)。 (8) 电梯运行的方向由先发出请求者决定,不允许后发出请求者改变电梯的当前运 行方向,除非是未被请求的空梯。 (9) 当某层有乘客按下乘梯电钮时,优先考虑离该层最近的、满足条件(8)、能够 最快到达目标层的电梯。 (10) 不允许电梯超员。 开发结果的行为特征 (1) 产生事件的周期为1 秒,每次可产生0 个或多个事件。 (2) 各随机事件由互不相关的伪随机数发生器决定。 (3) 设计一个易于理解的界面,动态显示各梯的载客与运行情况,动态显示各楼层 的人员停留情况与要求乘梯情况;动态显示从仿真开始到目前的时间。 (4) 显示时用应表示出不同的乘客及其当前所要求去往的楼层。例如,12-32 表示标 识为12 的乘客要求去往32 层。 (5) 统计各梯的运行与空闲时间;统计各人发出乘梯要求后的等待时间;仿真结束 后显示这些时间。 (6) 参数K、N、M、S、T 应从命令行输入。 (7) (选做)考虑有些乘客(随机决定)携带的物品体积较大,需占用1~2 人的电 梯空间(随机决定),且上下梯的时间比其他乘客长一倍的情况,再进行相应的仿真(注意, 不是所有的乘客都携带较大体积的物品)。这时,显示乘客及所去往的楼层时要能够识别出 是否携带了较大体积的物品。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值