CF1810E.Monsters
普及/提高-
通过率:0%
AC君温馨提醒
该题目为【codeforces】题库的题目,您提交的代码将被提交至codeforces进行远程评测,并由ACGO抓取测评结果后进行展示。由于远程测评的测评机由其他平台提供,我们无法保证该服务的稳定性,若提交后无反应,请等待一段时间后再进行重试。
题目描述
There is an undirected graph with n vertices and m edges. Initially, for each vertex i , there is a monster with danger ai on that vertex. For a monster with danger ai , you can defeat it if and only if you have defeated at least ai other monsters before.
Now you want to defeat all the monsters. First, you choose some vertex s and defeat the monster on that vertex (since you haven't defeated any monsters before, as has to be 0 ). Then, you can move through the edges. If you want to move from vertex u to vertex v , then the following must hold: either the monster on vertex v has been defeated before, or you can defeat it now. For the second case, you defeat the monster on vertex v and reach vertex v .
You can pass the vertices and the edges any number of times. Determine whether you can defeat all the monsters or not.
输入格式
Each test contains multiple test cases. The first line contains a single integer t ( 1≤t≤104 ) — the number of test cases. Their description follows.
The first line of each test case contains two integers n , m ( 1≤n,m≤2⋅105 ) — the number of vertices and edges in the graph respectively.
The second line of each test case contains n integers a1,a2,…,an ( 0≤ai≤n ) — the dangers of monsters on corresponding vertices.
For the following m lines, each line contains two integers u , v ( 1≤u,v≤n ), describing an edge connecting vertex u and vertex v . It is guaranteed that there are no multi-edges or self-loops in the graph.
It is guaranteed that both the sum of n and the sum of m over all test cases do not exceed 2⋅105 .
输出格式
For each test case, output "YES" if you can defeat all the monsters, or "NO" otherwise.
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.
输入输出样例
输入#1
5 4 3 2 1 0 3 1 2 2 3 3 4 6 6 0 1 2 3 0 1 1 2 2 3 3 4 4 5 4 6 5 6 4 3 0 1 2 0 1 2 2 3 1 3 4 6 1 1 1 0 1 2 3 2 4 3 2 4 4 1 1 3 5 5 0 1 3 2 0 1 2 2 3 3 4 4 5 3 5
输出#1
YES YES NO YES NO
说明/提示
In the first test case, you can start at vertex 3 and defeat the monster on it, before you go to vertices 2 , 1 in this order, defeating the monsters on them as well. Then you return to vertex 3 , and go to vertex 4 , defeating the monster on it.
In the third test case, there is no path to vertex 4 if you start at vertex 1 . Also, there is no path to vertices 1 , 2 , and 3 if you start at vertex 4 .