题目描述
黑板上写有 N 个集合 S1,S2,…,SN,每个集合由 1 到 M 之间的若干整数构成。具体地,$S\_i = \lbrace S\_{i,1}, S\_{i,2}, \dots, S\_{i,A\_i} \rbrace$。
你可以进行如下操作任意次(也可以一次都不做):
- 选择两个有至少一个公共元素的集合 X,Y,将它们从黑板上擦去,并将 X∪Y 写到黑板上。
这里,X∪Y 指的是由 X 或 Y 至少包含的元素组成的集合。
请判断是否可以通过若干次操作,得到一个同时包含 1 和 M 的集合。如果可以,输出所需操作次数的最小值;否则输出 −1。
输入格式
输入按以下格式从标准输入给出。
N M A1 S1,1 S1,2 … S1,A1 A2 S2,1 S2,2 … S2,A2 ⋮ AN SN,1 SN,2 … SN,AN
输出格式
如果可以得到同时包含 1 和 M 的集合,输出所需操作次数的最小值;否则输出 −1。
样例 1
输入
3 5
2
1 2
2
2 3
3
3 4 5
输出
2
样例 2
输入
1 2
2
1 2
输出
0
样例 3
输入
3 5
2
1 3
2
2 4
3
2 4 5
输出
-1
样例 4
输入
4 8
3
1 3 5
2
1 2
3
2 4 7
4
4 6 7 8
输出
2
说明/提示
限制条件
- 1≤N≤2×105
- 2≤M≤2×105
- 1≤∑i=1NAi≤5×105
- $1 \leq S\_{i,j} \leq M \ (1 \leq i \leq N, 1 \leq j \leq A\_i)$
- Si,j=Si,k (1≤j<k≤Ai)
- 输入均为整数。
样例解释 1
首先,选择 {1,2} 和 {2,3},合并为 {1,2,3}。然后,选择 {1,2,3} 和 {3,4,5},合并为 {1,2,3,4,5}。这样经过 2 次操作可以得到同时包含 1 和 M 的集合。由于一次操作无法达成目标,答案为 2。
样例解释 2
一开始 S1 就同时包含 1 和 M,因此最小操作次数为 0。
由 ChatGPT 4.1 翻译