#P13516. [KOI 2025 #1] 快递运输
[KOI 2025 #1] 快递运输
题目背景
试题来源:https://koi.or.kr/archives/。中文翻译做了少量本土化修改。
按照署名—非商业性使用—相同方式共享 4.0 协议国际版进行授权。
题目描述
2050 年,快递最优化研究所 (KOI, Kurier Optimization Institute) 建立了一个全国范围的基于机器人的快递运输网络。
该网络由 个物流中心和连接它们的 条道路组成,物流中心的编号从 1 到 。每条道路的编号从 1 到 ,其中第 条 () 道路连接着 和 两个物流中心,道路的长度为 。任何一个物流中心都可以通过一条或多条道路到达其他任何一个物流中心。也就是说,快递运输网络是一个由道路连接而成的连通结构。此外,任意两条不同的道路除了在它们的端点(即物流中心)外,不会在任何其他点相交。
我们将所有物流中心和所有道路上的任意点统称为一个地点。两个地点 之间的距离 定义为从地点 到达地点 必须经过的最短路径长度。当然,若 ,则 。
一些机器人被放置在特定的物流中心。每个机器人都带有一个给定的通信范围。一个通信范围为 、初始位于地点 的机器人,可以在满足 的所有地点 之间自由地、往复地移动,并可以在自己可移动范围内的任意地点取件或放件。
您作为研究所的研究员,需要判断是否可以利用协作的机器人,将快递从 1 号物流中心运输到 号物流中心。也就是说,一个机器人可以将快递放在某个地点,然后另一个机器人可以从同一地点取走快递并继续运输。
您需要对总共 个场景进行分析,这些场景是相互关联的。第 () 个场景的形态如下:
- 1 :在第 个场景的基础上,增加一个新机器人。该机器人的初始位置为 号物流中心,通信范围为 。
- 2 :在第 个场景的基础上,移除在第 个场景中添加的机器人。保证在第 个场景中确实添加了一个新的机器人,且同一个机器人不会被移除两次以上。
规定,第 0 个场景为初始状态,即没有任何机器人被放置。
对于每个场景,请编写一个程序来判断,机器人是否能够协作将快递从 1 号物流中心运输到 号物流中心。
输入格式
第一行给出两个整数 ,以空格分隔。
接下来的 行给出道路的信息。其中第 () 行包含三个整数 ,以空格分隔。
接下来的 行给出场景的信息。其中第 () 行是关于第 个场景的信息,格式如题面所述。
输出格式
输出 行。第 () 行输出在第 个场景下,如果快递能够被运输,则输出 YES,否则输出 NO。
11 10
1 3 3
2 3 10
3 4 5
4 5 8
9 6 4
4 7 2
7 8 2
5 9 1
9 10 2
5 11 3
1 1 4
1 2 12
1 6 6
1 7 1
1 8 8
1 9 6
1 10 9
1 11 2
2 7
2 1
NO
NO
NO
NO
NO
YES
YES
YES
YES
NO
提示
样例 1 说明
假设我们考虑第八个场景。此时总共放置了六个机器人。其中一种可能的运输方式如下:
- 位于 1 号物流中心的唯一一个机器人通信范围为 4。该机器人从 1 号物流中心拿起快递,并将其放在 3 号物流中心。
- 位于 2 号物流中心的唯一一个机器人通信范围为 12。该机器人从 3 号物流中心移动并拿起快递,然后将其放在从 3 号物流中心到 4 号物流中心的道路上,距离 3 号物流中心为 1 的位置。
- 位于 8 号物流中心的唯一一个机器人通信范围为 8。该机器人从 3 号到 4 号道路上距离 3 号物流中心为 1 的位置移动并拿起快递,然后将其放在从 4 号到 5 号道路上距离 4 号物流中心为 3 的位置。
- 位于 10 号物流中心的唯一一个机器人通信范围为 9。该机器人从 4 号到 5 号道路上距离 4 号物流中心为 3 的位置移动并拿起快递,然后将其放在 11 号物流中心。
因为可以运输快递,所以应当输出 YES。
假设我们考虑第十个场景。此时总共放置了六个机器人。没有任何机器人能够拿起最初放在 1 号物流中心的快递。因此,无法运输快递。所以应当输出 NO。
限制条件
- 给定的所有数都是整数。
- 对于每个 的 ,有 且 。
- 运输网络是连通的。
- 对于每个 的 :
- 如果第 个场景是增加新机器人,则 且 。
- 如果第 个场景是移除机器人,则 且第 个场景必须是增加新机器人的场景。同一个机器人不会被移除超过一次。
子任务
- (8 分) 。对于每个 的 ,。
- (13 分) 对于每个 的 ,。此外,。
- (25 分) 。
- (27 分) 对于每个 的 ,。
- (30 分) 所有的场景都是增加新机器人的场景。
- (26 分) 对于每个 的 ,。对于所有 ,如果是增加新机器人的场景,。
- (21 分) 无附加限制条件。