CF1919G.Tree LGM
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
In TreeWorld, there is a popular two-player game played on a tree with n vertices labelled from 1 to n . In this game, the tournament leaders first choose a vertex to be the root of the tree and choose another vertex (possibly the same vertex as the root) to place a coin on. Then, each player will take turns moving the coin to any child † of the vertex that the coin is currently on. The first player who is unable to make a move loses.
Alice wants to be a tree LGM, so she spends a lot of time studying the game. She wrote down an n by n matrix s , where si,j=1 if the first player can win with the root of the tree chosen to be vertex i , and the coin was initially placed on vertex j . Otherwise, si,j=0 . Alice is a perfectionist, so she assumes that both players play perfectly in the game.
However, she accidentally knocked her head on the way to the tournament and forgot what the tree looked like. Determine whether there exists a tree that satisfies the winning and losing states represented by matrix s , and if it exists, construct a valid tree.
† A vertex c is a child of vertex u if there is an edge between c and u , and c does not lie on the unique simple path from the root to vertex u .
输入格式
The first line contains a single integer n ( 1≤n≤5000 ) — the number of vertices in the tree.
Each of the next n lines contains a string with n characters, the j -th character of the i -th line representing si,j ( si,j∈{0,1} ) — the winning and losing states of the tree.
输出格式
If there is no tree satisfying the winning and losing states represented by matrix s , print a single line containing "NO".
Otherwise, if there exists a tree satisfying matrix s , print "YES" on the first line, followed by n−1 lines each containing two integers u and v ( 1≤u,v≤n ) representing that the tree has an edge between vertices u and v .
You can output the answer in any case (upper or lower). For example, the strings "yEs", "yes", "Yes", and "YES" will be recognized as positive responses.
If there are multiple trees satisfying the winning and losing states represented by matrix s , print any of them.
输入输出样例
输入#1
4 1100 0101 0011 0101
输出#1
YES 4 1 3 2 2 4
输入#2
3 001 010 100
输出#2
NO
说明/提示
In the first test case, the line graph 1−4−2−3 satisfies the winning and losing states represented by matrix s . For example, s3,3=1 as the first player can move the coin from 3→2 , then the second player moves the coin from 2→4 , and finally, the first player moves the coin from 4→1 . At this point, 1 has no children, so the second player is unable to make a move and loses. On the other hand, s1,3=0 as if 1 is the root, then 3 has no children so the first player is unable to make the first move and loses.
In the second test case, it is possible to prove that no tree satisfies the winning and losing states represented by matrix s .