#ATabc302f. [ABC302F] Merge Set

[ABC302F] Merge Set

题目描述

黑板上写有 NN 个集合 S1,S2,,SNS_1,S_2,\dots,S_N,每个集合由 11MM 之间的若干整数构成。具体地,$S\_i = \lbrace S\_{i,1}, S\_{i,2}, \dots, S\_{i,A\_i} \rbrace$。

你可以进行如下操作任意次(也可以一次都不做):

  • 选择两个有至少一个公共元素的集合 X,YX,Y,将它们从黑板上擦去,并将 XYX \cup Y 写到黑板上。

这里,XYX \cup Y 指的是由 XXYY 至少包含的元素组成的集合。

请判断是否可以通过若干次操作,得到一个同时包含 11MM 的集合。如果可以,输出所需操作次数的最小值;否则输出 1-1

输入格式

输入按以下格式从标准输入给出。

NN MM A1A_1 S1,1S_{1,1} S1,2S_{1,2} \dots S1,A1S_{1,A_1} A2A_2 S2,1S_{2,1} S2,2S_{2,2} \dots S2,A2S_{2,A_2} \vdots ANA_N SN,1S_{N,1} SN,2S_{N,2} \dots SN,ANS_{N,A_N}

输出格式

如果可以得到同时包含 11MM 的集合,输出所需操作次数的最小值;否则输出 1-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

说明/提示

限制条件

  • 1N2×1051 \leq N \leq 2 \times 10^5
  • 2M2×1052 \leq M \leq 2 \times 10^5
  • 1i=1NAi5×1051 \leq \sum_{i=1}^{N} A_i \leq 5 \times 10^5
  • $1 \leq S\_{i,j} \leq M \ (1 \leq i \leq N, 1 \leq j \leq A\_i)$
  • Si,jSi,k (1j<kAi)S_{i,j} \neq S_{i,k} \ (1 \leq j < k \leq A_i)
  • 输入均为整数。

样例解释 1

首先,选择 {1,2}\lbrace 1,2 \rbrace{2,3}\lbrace 2,3 \rbrace,合并为 {1,2,3}\lbrace 1,2,3 \rbrace。然后,选择 {1,2,3}\lbrace 1,2,3 \rbrace{3,4,5}\lbrace 3,4,5 \rbrace,合并为 {1,2,3,4,5}\lbrace 1,2,3,4,5 \rbrace。这样经过 22 次操作可以得到同时包含 11MM 的集合。由于一次操作无法达成目标,答案为 22

样例解释 2

一开始 S1S_1 就同时包含 11MM,因此最小操作次数为 00

由 ChatGPT 4.1 翻译