#P15448. [IOI 2011] Tropical Garden
[IOI 2011] Tropical Garden
说明
植物学家 Somhed 定期带领学生团体参观泰国最大的热带花园之一。这个花园的景观由 个喷泉(编号为 )和 条小径组成。每条小径连接一对不同的喷泉,并且可以双向通行。每个喷泉至少有一条小径离开。这些小径沿途有 Somhed 想要欣赏的美丽植物收藏。每个团体可以从任意喷泉开始他们的行程。
Somhed 热爱美丽的热带植物。因此,从任何一个喷泉出发,他和他的学生们会走离开该喷泉的最美丽的小径,除非这条小径是刚刚走过的并且有另一条可选。在这种情况下,他们会改走第二美丽的小径。当然,如果没有可选的小径,他们会原路返回,第二次使用同一条小径。注意,由于 Somhed 是专业植物学家,对他来说没有两条小径是同样美丽的。
他的学生们对植物不太感兴趣。不过,他们非常想在位于编号为 的喷泉旁的顶级餐厅吃午餐。Somhed 知道他的学生们会在恰好走了 条小径后感到饥饿, 的值可能因学生团体而异。Somhed 想知道他可以为每个团体选择多少条不同的路线,给定以下条件:
- 每个团体可以从任意喷泉出发;
- 连续选择的小径必须按照上述方式;
- 每个团体必须在恰好走了 条小径后,在 号喷泉结束。
注意,他们可以在路线中提前经过 号喷泉,尽管他们仍然需要在 号喷泉结束路线。
交互细节
根据给出的喷泉和小径信息,你需要为 个学生团体找出答案;也就是说,为 个 的值找出答案。
编写一个过程 count_routes(N, M, P, R, Q, G),它接受以下参数:
- - 喷泉的数量。喷泉编号为 到 。
- - 小径的数量。小径编号为 到 。小径将按美丽程度降序给出:对于 ,小径 比小径 更美丽。
- - 顶级餐厅所在的喷泉。
- - 一个表示小径的二维数组。对于 ,小径 连接喷泉 和 。回想一下,每条小径连接一对不同的喷泉,并且没有两条小径连接同一对喷泉。
- - 学生团体的数量。
- - 一个包含 值的一维整数数组。对于 , 是第 个团体将要走的路径数量 。
对于 ,你的过程必须找出第 个团体可能采取的、恰好有 条小径且能到达 号喷泉的路线数量。对于每个团体 ,你的过程应该调用过程 answer(X) 来报告路线数量为 。答案必须按团体的相同顺序给出。如果没有有效路线,你的过程必须调用 answer(0)。
交互示例
示例 1

考虑图 1 所示的情况,其中 ,并且
1 2
0 1
0 3
3 4
4 5
1 5
注意小径是按美丽程度递减列出的。也就是说,小径 是最美丽的,小径 是第二美丽的,依此类推。
只有两条可能的有效路线能恰好走 条小径:
,以及
。
第一条路线从喷泉 开始。从这里出发的最美丽小径通向喷泉 。在喷泉 处,团体别无选择,必须沿同一条小径返回。回到喷泉 后,团体现在将避免走小径 ,而是选择小径 。这条小径确实将他们带到了 号喷泉。
因此,该过程应该调用 answer(2)。
示例 2

考虑图 2 所示的情况,其中 ,并且
1 0
1 2
3 2
1 3
4 2
对于第一个团体,只有一条有效路线能在走 条小径后到达喷泉 :。
对于第二个团体,有两条有效路线能在走 条小径后到达喷泉 : 和 。
因此,count_routes 的正确实现应该首先调用 answer(1) 来报告第一个团体的答案,然后调用 answer(2) 来报告第二个团体的答案。
输入格式
示例评分器按以下格式读取输入:
- 第 行:、 和 。
- 第 行到第 行:小径的描述;即第 行包含 和 ,以空格分隔,其中 。
- 第 行:。
- 第 行:数组 ,为一串空格分隔的整数序列。
- 第 行:预期解的数组,为一串空格分隔的整数序列。
输出格式
示例评分器输出:对于此任务,这些文件中的每一个都应精确地包含文本 Correct.
提示
数据范围
- 子任务 1 (49 分)
- 的每个元素是介于 和 之间的整数(含端点)。
- 子任务 2 (20 分)
- 的每个元素是介于 和 之间的整数(含端点)。
- 子任务 3 (31 分)
- 的每个元素是介于 和 之间的整数(含端点)。
京公网安备 11011102002149号