CF1868D.Flower-like Pseudotree

普及/提高-

通过率:0%

AC君温馨提醒

该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。

题目描述

A pseudotree is a connected graph which has exactly one cycle and no self-loops. Note that a pseudotree may contain multiple-edges. It can be shown that a pseudotree with nn vertices always contains nn edges.

After deleting all edges on the cycle in the pseudotree, a forest ^{\dagger} will be formed. It can be shown that each tree in the forest will contain exactly one vertex which is on cycle before removing the edges. If all trees in the forest have the same depth ^{\ddagger} when picking the vertex on cycle as root, we call the original pseudotree flower-like.

Our friend sszcdjr, had a flower-like pseudotree with nn vertices and nn edges. However, he forgot all the edges in the pseudotree. Fortunately, he still remembers the degrees of vertices. Specifically, the degree of the ii -th vertex is did_i .

You have to help sszcdjr construct a possible flower-like pseudotree with nn vertices, where the degree of the ii -th vertex is exactly did_i , or tell him that it is impossible.

^{\dagger} A forest is a graph in which all connectivity components are trees. A connected graph without cycles and self-loops is called a tree.

^{\ddagger} The depth of a tree with a root is the maximum distance from the root to the vertex of this tree.

输入格式

The first line of the input contains a single integer tt ( 1t1051\leq t\leq 10^5 ) — the number of test cases. The description of test cases follows.

The first line of each test case contains a single integer nn ( 2n1062\leq n\leq 10^6 ) — the number of vertices.

The second line of each test case contains nn integers d1,d2,,dnd_1,d_2,\ldots,d_n ( 1din1\leq d_i\leq n ) — the degree of each vertex.

It is guaranteed that the sum of nn over all test cases does not exceed 10610^6 .

输出格式

For each test case, if there exist a possible flower-like pseudotree:

  • Print "Yes" (without quotes) in the first line.
  • Then, output nn lines, in each line print two integers uiu_i and viv_i — the two vertices that the ii -th edge connects.

If there are multiple answers, you may output any of them.

Otherwise, print "No" (without quotes) in the only line of output.

You can output the first line of each test case in any case (upper or lower). For example, the strings "yEs", "yes", "Yes", and "YES" will be recognized as positive responses.

输入输出样例

  • 输入#1

    6
    3
    2 2 2
    4
    1 2 3 4
    7
    4 3 3 1 1 1 1
    6
    1 1 2 2 3 3
    10
    1 1 5 2 1 1 1 1 1 6
    9
    1 1 3 1 1 4 1 1 5

    输出#1

    Yes
    1 2
    2 3
    3 1
    No
    Yes
    1 2
    2 3
    3 1
    1 4
    1 5
    2 6
    3 7
    Yes
    5 6
    6 5
    1 3
    2 4
    3 5
    4 6
    No
    Yes
    3 6
    6 9
    9 3
    1 3
    2 6
    4 6
    5 9
    7 9
    8 9

说明/提示

In the first test case, the only possible flower-like psuedotree is:

After deleting all edges on the cycle in the pseudotree, each tree has depth 00 .

In the second test case, it can be proven that there's no such flower-like psuedotree.

In the third test case, one of the possible flower-like psuedotrees is:

首页