蓝桥杯2595: 蓝桥杯2020年第十一届国赛真题-出租车题解

arkfactor 算法基础篇 43 0
挑战自我,勇攀编程高峰!全网最全C++题库,助您成为编程达人。
小蓝在 L 市开出租车,看到绿灯,如果刚好由绿灯变为红灯,则视为看到红灯,每段道路都是双向道路,道路中间有隔离栏杆,在道路中间不能掉头,只能在红绿灯路口掉头,掉头时不管是红灯还是绿灯都可以直接掉头,掉头的时间可以忽略,小蓝时刻 0 从家出发,今天,他接到了 q 个预约的订单,他打算按照订单的顺序依次完成这些订单,就回家休息,中途小蓝不准备再拉其他乘客。

小蓝在 L 市开出租车。 L 市的规划很规整,所有的路都是正东西向或者正南北向的,道路都可以看成直线段。东西向的道路互相平行,南北向的道路互相平行,任何一条东西向道路垂直于任何一条南北向道路。 从北到南一共有 n 条东西向道路,依次标号为 H 1 , H 2 , ···, H n 。从西到东一共有 m 条南北向的道路,依次标号为 S 1 , S 2 , ···, S m 。每条道路都有足够长,每一条东西向道路和每一条南北向道路都相交,H i与 S j 的交叉路口记为 (i, j)。从 H 1 和 S 1 的交叉路口 (1,1) 开始,向南遇到的路口与 (1,1) 的距离分别是 h 1 , h 2 , ···, h n−1 ,向东遇到路口与 (1,1) 的距离分别是 w 1 , w 2 , ···, w m−1 。道路的每个路口都有一个红绿灯。时刻 0 的时候,南北向绿灯亮,东西向红灯亮,南北向的绿灯会持续一段 时间(每个路口不同),然后南北向变成红灯,东西向变成绿灯,持续一段时间后,再变成南北向绿灯,东西向红灯。 已知路口 (i, j) 的南北向绿灯每次持续的时间为 g ij ,东西向的绿灯每次持续的时间为 r ij ,红绿灯的变换时间忽略。 当一辆车走到路口时,如果是绿灯,可以直行、左转或右转。如果是红灯,可以右转,不能直行或左转。如果到路口的时候刚好由红灯变为绿灯,则视为 看到绿灯,如果刚好由绿灯变为红灯,则视为看到红灯。每段道路都是双向道路,道路中间有隔离栏杆,在道路中间不能掉头,只能在红绿灯路口掉头。掉头时不管是红灯还是绿灯都可以直接掉头。掉头的时间可以忽略。小蓝时刻 0 从家出发。今天,他接到了 q 个预约的订单,他打算按照订单的顺序依次完成这些订单,就回家休息。中途小蓝不准备再拉其他乘客。 小蓝的家在两个路口的中点,小蓝喜欢用 x 1 , y 1 , x 2 , y 2 来表示自己家的位置,即路口 (x 1 ,y 1 ) 到路口 (x 2 ,y 2 ) 之间的道路中点的右侧,保证两个路口相邻(中间没有其他路口)。请注意当两个路口交换位置时,表达的是路的不同两边,路中间有栏杆,因此这两个位置实际要走比较远才能到达。小蓝的订单也是从某两个路口间的中点出发,到某两个路口间的中点结束。小蓝必须按照给定的顺序处理订单,而且一个时刻只能处理一个订单,不能图省时间而同时接两位乘客,也不能插队完成后面的订单。小蓝只对 L 市比较熟,因此他只会在给定的 n 条东西向道路和 m 条南北向道路上行驶,而且不会驶出 H 1 , H n , S 1 , S m 这几条道路所确定的矩形区域(可以到边界)。小蓝行车速度一直为 1,乘客上下车的时间忽略不计。请问,小蓝最早什么时候能完成所有订单回到家。

蓝桥杯2595: 蓝桥杯2020年第十一届国赛真题-出租车题解
-第1张图片-东莞河马信息技术
(图片来源网络,侵删)
不断挑战自我,才能突破极限!全网最全C++题库,让您在编程道路上越走越远。

标签: 蓝桥杯2595: 蓝桥杯2020年第十一届国赛真题-出租车题解