题目描述
译自 JOISC 2018 Day3 T2「ビ太郎のパーティー / Bitaro’s Party」

河狸们有 N 个城镇,这些城镇按照海拔从高到低依次编号为 1…N(保证海拔互不相同)。有 M 条运河,i 号运河从城镇 Si 流向 Ei。所有的运河都从海拔高的地方流向海拔低的地方。河狸们不能沿着运河逆流而上,即:河狸不能从城镇 Ei 通过 i 号运河前往城镇 Si。
河狸比太郎有在每个城镇各有一位朋友。比太郎打算举办 Q 场聚会。第 j 场聚会在城镇 Tj 进行,已知有 Yj 名河狸因事无法参加。在剩下的河狸中,除非他无法从他所在的城镇到达 Tj,否则他一定会来。
因为河狸们十分喜欢运河,所以他们会沿经过运河数目最多的一条路径参加聚会,比太郎想知道每次聚会经过运河数目最多的河狸会经过多少条运河。
任务
给定 Q 场聚会举行的城镇编号和因事无法参加的河狸列表,写一个程序求出参加每次聚会经过运河数目最多的河狸会经过多少条运河。
输入格式
从标准输入中读入如下内容:
- 输入的第一行包含三个用空格隔开的整数 N,M,Q,表示有 N 个河狸城镇,M 条运河,要举行 Q 场聚会;
- 接下来 M 行,第 i 行有两个用空格隔开的整数 Si,Ei,表示运河单向地从 Si 流向 Ei;
- 接下来 Q 行,第 j 行包含一些整数,前两个用空格分开的整数 Tj,Yj,后面有 Yj 个用空格隔开的整数 Cj,1,Cj,2,⋯,Cj,Yj,表示第 j 场聚会在 Tj 镇举行,住在 Cj,1,Cj,2,⋯,Cj,Yj 的河狸因事不能来参加聚会。
输出格式
输出 Q 行,第 j 行包含一个整数,表示参加每次聚会经过运河数目最多的河狸会经过多少条运河。如果没有河狸能参加这场聚会,输出 −1。
数据范围与提示
对于全部数据,满足以下条件:
- 1≤N≤105
- 0≤M≤2×105
- 1≤Q≤105
- 1≤Si<Ei≤N (1≤i≤N)
- (Si,Ei)=(Sj,Ej) (1≤j≤M)
- 1≤Tj≤N (1≤j≤Q)
- 0≤Yj≤N (1≤j≤Q)
- 1≤Cj,1<Cj,2<⋯<Cj,Yj≤N (1≤j≤Q)
- Y1+Y2+⋯YQ≤105
本题包含三个子任务,具体子任务限制如下:
Subtask |
附加限制 |
分数 |
1 |
N≤103,M≤2×103,Q=1 |
7 |
2 |
Q=1 |
3 |
无附加限制 |
86 |