← Home
write a go solution for Description:
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 n vertices always contains n 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 n vertices and n edges. However, he forgot all the edges in the pseudotree. Fortunately, he still remembers the degrees of vertices. Specifically, the degree of the i-th vertex is d_i.

You have to help sszcdjr construct a possible flower-like pseudotree with n vertices, where the degree of the i-th vertex is exactly d_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.

Input Format:
The first line of the input contains a single integer t (1<=qt<=q10^5) — the number of test cases. The description of test cases follows.

The first line of each test case contains a single integer n (2<=n<=10^6) — the number of vertices.

The second line of each test case contains n integers d_1,d_2,ldots,d_n (1<=qd_i<=qn) — the degree of each vertex.

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

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

- Print "Yes" (without quotes) in the first line.
- Then, output n lines, in each line print two integers u_i and v_i — the two vertices that the i-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.

Note:
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 0.

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:. Output only the code with no comments, explanation, or additional text.