CF1680F.Lenient Vertex Cover
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
You are given a simple connected undirected graph, consisting of n vertices and m edges. The vertices are numbered from 1 to n .
A vertex cover of a graph is a set of vertices such that each edge has at least one of its endpoints in the set.
Let's call a lenient vertex cover such a vertex cover that at most one edge in it has both endpoints in the set.
Find a lenient vertex cover of a graph or report that there is none. If there are multiple answers, then print any of them.
输入格式
The first line contains a single integer t ( 1≤t≤104 ) — the number of testcases.
The first line of each testcase contains two integers n and m ( 2≤n≤106 ; n−1≤m≤min(106,2n⋅(n−1)) ) — the number of vertices and the number of edges of the graph.
Each of the next m lines contains two integers v and u ( 1≤v,u≤n ; v=u ) — the descriptions of the edges.
For each testcase, the graph is connected and doesn't have multiple edges. The sum of n over all testcases doesn't exceed 106 . The sum of m over all testcases doesn't exceed 106 .
输出格式
For each testcase, the first line should contain YES if a lenient vertex cover exists, and NO otherwise. If it exists, the second line should contain a binary string s of length n , where si=1 means that vertex i is in the vertex cover, and si=0 means that vertex i isn't.
If there are multiple answers, then print any of them.
输入输出样例
输入#1
4 6 5 1 3 2 4 3 4 3 5 4 6 4 6 1 2 2 3 3 4 1 4 1 3 2 4 8 11 1 3 2 4 3 5 4 6 5 7 6 8 1 2 3 4 5 6 7 8 7 2 4 5 1 2 2 3 3 4 1 3 2 4
输出#1
YES 001100 NO YES 01100110 YES 0110
输入#2
1 10 15 9 4 3 4 6 4 1 2 8 2 8 3 7 2 9 5 7 8 5 10 1 4 2 10 5 3 5 7 2 9
输出#2
YES 0101100100
输入#3
1 10 19 7 9 5 3 3 4 1 6 9 4 1 4 10 5 7 1 9 2 8 3 7 3 10 9 2 10 9 8 3 2 1 5 10 7 9 5 1 2
输出#3
YES 1010000011
说明/提示
Here are the graphs from the first example. The vertices in the lenient vertex covers are marked red.