New Road Network

题意翻译

### 题目描述 有 $n$ 个点和 $m$ 个集合,需要构造出一棵树使得对于 $1\leq i\leq m$,属于集合 $i$ 的所有点构成一个连通块。如果方案存在输出 `YES` 并给出方案,否则输出 `NO`。 ### 输入格式 第一行一个整数 $T$ 表示数据组数。 每组数据的第一行为两个整数 $n,m$,表示点数和集合数。 接下来 $m$ 行,每行一个长度为 $n$ 的 $01$ 串,表示第 $i$ 个集合的信息。如果第 $i$ 行的第 $j$ 个字符为 $1$ 则表示点 $j$ 属于集合 $i$,为 $0$ 则表示不属于。 ### 输出格式 对于每组测试数据,如果能构造出一组方案,输出 `YES` 和一组合法方案,否则输出 `NO`。 Translated By Karry5307

题目描述

The king of some country $ N $ decided to completely rebuild the road network. There are $ n $ people living in the country, they are enumerated from $ 1 $ to $ n $ . It is possible to construct a road between the house of any citizen $ a $ to the house of any other citizen $ b $ . There should not be more than one road between any pair of citizens. The road network must be connected, i.e. it should be possible to reach every citizen starting from anyone using roads. To save funds, it was decided to build exactly $ n-1 $ road, so the road network should be a tree. However, it is not that easy as it sounds, that's why the king addressed you for help. There are $ m $ secret communities in the country, each of them unites a non-empty subset of citizens. The king does not want to conflict with any of the communities, so he wants to build the network such that the houses of members of each society form a connected subtree in network. A set of vertices forms a connected subtree if and only if the graph remains connected when we delete all the other vertices and all edges but ones that connect the vertices from the set. Help the king to determine if it is possible to build the desired road network, and if it is, build it.

输入输出格式

输入格式


Each test consists of one or more test cases. The first line contains a single integer $ t $ ( $ 1 \leq t \leq 2000 $ ) — the number of test cases. The following lines describe the test cases, each in the following format. The first line contains two integers $ n $ and $ m $ ( $ 1 \leq n, m \leq 2000 $ ) — the number of citizens and the number of secret communities. The next $ m $ lines contain the description of the communities. The $ i $ -th of these lines contains a string $ s_i $ of length $ n $ , consisting of characters '0' and '1'. The citizen with number $ j $ is a member of the $ i $ -th community if and only if $ s_{{i}{j}}=1 $ . It is guaranteed that the string $ s_i $ contains at least one character '1' for each $ 1 \leq i \leq m $ . It is guaranteed that the sum of $ n $ for all test cases does not exceed $ 2000 $ and the sum of $ m $ for all test cases does not exceed $ 2000 $ .

输出格式


Print the answer for all test cases in the order they are given in the input, each in the following format. If there is no way to build the desired road network, print "NO" (without quotes). Otherwise in the first line print "YES" (without quotes). In the next $ n-1 $ lines print the description of the road network: each line should contain two integers $ a $ and $ b $ ( $ 1 \leq a, b \leq n $ , $ a \neq b $ ) that denote you build a road between houses of citizens $ a $ and $ b $ . The roads should form a connected tree, and each community should form a connected subtree.

输入输出样例

输入样例 #1

2
4 3
0011
1110
0111
3 3
011
101
110

输出样例 #1

YES
1 3
2 3
3 4
NO

说明

In the first example you can build the following network: ![](https://cdn.luogu.com.cn/upload/vjudge_pic/CF1054G/2c9fa0f78ef5d14cd2be80686c4e7e4ee5036e9e.png)It is easy to see that for each community all the houses of its members form a connected subtree. For example, the $ 2 $ -nd community unites the citizens $ 1 $ , $ 2 $ , $ 3 $ . They form a connected subtree, because if we delete everything except the houses $ 1 $ , $ 2 $ , $ 3 $ and the roads between them, two roads will remain: between $ 1 $ and $ 3 $ and between $ 2 $ and $ 3 $ , forming a connected graph. There is no network in the second example suitable for the king.