一栋10层的大楼(楼层编号1-10),设有一台无限载重的电梯,初始时电梯停在1层。电梯移动1层的耗时为1,在某一层停靠的耗时为1(时间初始为0)。为了使得乘客等待的时间(电梯在目的层的停靠时刻 - 乘客发出请求时刻)总和最小,请你编写一个程序来进行电梯调度。html
输入有5个请求,每一个请求一行,格式为请求时刻 起始楼层数 去往方向
,其中方向为0
表明向上去往10层,为1
表明向下去往1层。
输出每次对应的决策,每一行的输出格式为xx时,停靠在x楼
。其中,“xx时刻”指的是在某层楼停靠的时刻,且不算入在该层的停靠时间。如:git
0 1 0
,那么电梯从1层接客(1s)前往10层(9s),应输出10时,停靠在10楼
(1+9=10)。此时,该乘客等待时间为(10-0=)10。0 2 0
,那么电梯从1层前往2层(1s),接上乘客(1s),前往10层(8s),应输出10时,停靠在10楼
(1+1+8=10)。此时,该乘客等待时间为(10-0=)10s。最后输出完成5个请求(全部乘客都到达目的地)后,各乘客的等待时间总和。github
请本身设计5组测试用例,且具备必定表明性,用以验证程序是不是最小耗时。算法
编程语言选择C或C++均可以,但须要符合编码规范,且必需要有注释。要求在github上创建一个仓库,将本次做业代码提交到该仓库,并在博客开头给出仓库地址。注意:commit信息要遵照必定的git规范(可参看:git commit 规范指南),git必须使用命令行操做,不要使用github图形界面(可参看:廖雪峰Git教程)。编程
看完问题开始写,直接冲着最优,码了六七十行,果断放弃,我还年轻,我不想掉头发😭
咨询了学姐仍是决定从最简单的开始开始吧
提交的跟咱们平常单部电梯运行的算法比较相似(不能预知请求)
就是判断接下来的时间路径上是否有人能够搭顺风车,最大的通病是,电梯在2~9层并不会掉头
由于对象的概念和用法并非很了解,因此用告终构体来实现乘客的数据管理。
最终提交代码:segmentfault
version | 行数 | debug数 | 用时 |
---|---|---|---|
initial | 85(117) | 16 | 10h |
继续改进中 编程语言