该比赛已结束,您无法在比赛模式下递交该题目。您可以点击“在题库中打开”以普通模式查看和递交本题。
徐老师的集合合并
题目描述
小徐老师给你 n 个集合 S1,S2,…,Sn,其中每个集合里的元素是 1 到 m 之间的整数。
你需要选择一些集合(可以一个都不选,也可以全选),使得从 1 到 m 的每个整数至少在一个被选中的集合中出现。
请判断是否有至少三种不同的方式选择集合,使上述条件成立。
输入格式
每组测试数据包含多组测试用例。第一行为测试用例组数 t(1≤t≤104)。接下来是各组测试数据。
每个测试用例的第一行为两个整数 n 和 m(2≤n≤5⋅104,1≤m≤105),分别表示集合数和整数范围上界。
接下来 n 行,第 i 行首先包含一个整数 li(1≤li≤m),表示第 i 个集合的大小。紧接着包含 li 个整数 Si,1,Si,2,…,Si,li($1 \le S_{i,1} < S_{i,2} < \dots < S_{i,l_{i}} \le m$),表示 Si 的元素。
记 L=∑i=1nli。保证:
- 所有测试用例中 n 的总和不超过 5⋅104;
- 所有测试用例中 m 的总和不超过 105;
- 所有测试用例中 L 的总和不超过 2⋅105。
输出格式
对于每个测试用例,如果存在至少三种不同的选择集合的方案,输出 YES,否则输出 NO。
输入输出样例 #1
输入 #1
6
3 2
2 1 2
1 1
1 2
4 10
3 1 2 3
2 4 5
1 6
4 7 8 9 10
2 5
4 1 2 3 4
4 1 2 3 4
5 5
5 1 2 3 4 5
5 1 2 3 4 5
5 1 2 3 4 5
5 1 2 3 4 5
5 1 2 3 4 5
5 10
4 1 2 3 4
5 1 2 5 6 7
5 2 6 7 8 9
4 6 7 8 9
2 9 10
5 5
1 1
1 2
1 3
2 4 5
1 5
输出 #1
YES
NO
NO
YES
YES
NO
说明/提示
在第一个测试用例中,存在 5≥3 种选择方案:
- 只选 S1,那么 1 和 2 都包含在 S1 中;
- 选 S1 和 S2,那么 1 包含在 S1 和 S2,2 包含在 S1;
- 选 S1 和 S3,那么 1 包含在 S1,2 包含在 S1 和 S3;
- 选 S2 和 S3,那么 1 包含在 S2,2 包含在 S3;
- 选 S1、S2 和 S3,那么 1 包含在 S1 和 S2,2 包含在 S1 和 S3。
注意,单独选 S2 是不合法的,因为 2 不包含在 S2 中。
在第二个测试用例中,只有唯一的一种方式就是全部选上所有集合。
在第三个测试用例中,5 没有出现在任意一个集合中,因此无法选择满足条件的集合。
在第四个测试用例中,任选非空的集合组合都满足条件,所以方案数为 25−1=31≥3。
数据范围与子任务
| 子任务 |
分值 |
数据范围 |
| 1∼3 |
10 |
2≤n≤20, 1≤m≤15, ∑li≤200 |
| 4∼6 |
15 |
2≤n≤200, 1≤m≤800, ∑li≤5000 |
| 7∼12 |
25 |
2≤n≤2000, 1≤m≤12000, ∑li≤5×104 |
| 13∼18 |
30 |
2≤n≤5×104, 1≤m≤25, ∑li≤2×105 |
| 19∼21 |
20 |
2≤n≤5×104, 1≤m≤105, ∑li≤2×105 |