如果您有一个国家/地区的完整巴士时刻表,您如何找出 1 天内两个指定站点之间可载客的最大人数?
我假设巴士时刻表为您提供每个巴士站的出发和到达时间的完整列表以及每辆巴士的容量。您在问题中得到了开始和结束。
您可以确定一系列公共汽车,以最短的时间到达目的地,并填满从一开始沿着这条路径离开的所有公共汽车,然后当每辆公共汽车到达一个站点时,只需将尽可能多的乘客转移到下一个站点离开的巴士。然而,这没有理由应该具有最大容量。
这个问题最快可以解决什么?例如,假设对于 M 个城市,我总共有 N 条记录;路线记录 Rᵢ 包含号码 Kᵢ、容量 Cᵢ,以及 Kᵢ 城市号码、Kᵢ 到达时间和 Kᵢ 出发时间的列表。(Rᵢ 中的第一个到达时间和最后一个离开时间无关。)广度优先搜索程序可以在 O(M*N) 时间内解决这个问题吗?