#S0104. Degree of Spanning Tree

Degree of Spanning Tree

题目描述

Given an undirected connected graph with nn vertices and mm edges, your task is to find a spanning tree of the graph such that for every vertex in the spanning tree its degree is not larger than n2\frac{n}{2}.

Recall that the degree of a vertex is the number of edges it is connected to.

输入格式

There are multiple test cases. The first line of the input contains an integer TT indicating the number of test cases. For each test case:

The first line contains two integers nn and mm (2n1052 \le n \le 10^5, n1m2×105n-1 \le m \le 2 \times 10^5) indicating the number of vertices and edges in the graph.

For the following mm lines, the ii-th line contains two integers uiu_i and viv_i (1ui,vin1 \le u_i, v_i \le n) indicating that there is an edge connecting vertex uiu_i and viv_i. Please note that there might be self loops or multiple edges.

It's guaranteed that the given graph is connected. It's also guaranteed that the sum of nn of all test cases will not exceed 5×1055 \times 10^5, also the sum of mm of all test cases will not exceed 10610^6.

输出格式

For each test case, if such spanning tree exists first output Yes in one line, then for the following (n1)(n-1) lines print two integers pip_i and qiq_i on the ii-th line separated by one space, indicating that there is an edge connecting vertex pip_i and qiq_i in the spanning tree. If no valid spanning tree exists just output No in one line.

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

Note

For the first sample test case, the maximum degree among all vertices in the spanning tree is 3 (both vertex 1 and vertex 4 has a degree of 3). As 3623 \le \frac{6}{2} this is a valid answer.

For the second sample test case, it's obvious that any spanning tree will have a vertex with degree of 2, as 2>322 > \frac{3}{2} no valid answer exists.

题目大意

给定一张 nnmm 边无向图,求一个生成树满足以下条件:

  • 每个点的度数都不大于 n2\dfrac{n}{2}