← Home
write a go solution for Description:
You are given a directed graph G which can contain loops (edges from a vertex to itself). Multi-edges are absent in G which means that for all ordered pairs (u,v) exists at most one edge from u to v. Vertices are numbered from 1 to n.

A path from u to v is a sequence of edges such that:

- vertex u is the start of the first edge in the path;
- vertex v is the end of the last edge in the path;
- for all pairs of adjacent edges next edge starts at the vertex that the previous edge ends on.

We will assume that the empty sequence of edges is a path from u to u.

For each vertex v output one of four values:

- 0, if there are no paths from 1 to v;
- 1, if there is only one path from 1 to v;
- 2, if there is more than one path from 1 to v and the number of paths is finite;
- -1, if the number of paths from 1 to v is infinite.

Let's look at the example shown in the figure.

Then:

- the answer for vertex 1 is 1: there is only one path from 1 to 1 (path with length 0);
- the answer for vertex 2 is 0: there are no paths from 1 to 2;
- the answer for vertex 3 is 1: there is only one path from 1 to 3 (it is the edge (1,3));
- the answer for vertex 4 is 2: there are more than one paths from 1 to 4 and the number of paths are finite (two paths: [(1,3),(3,4)] and [(1,4)]);
- the answer for vertex 5 is -1: the number of paths from 1 to 5 is infinite (the loop can be used in a path many times);
- the answer for vertex 6 is -1: the number of paths from 1 to 6 is infinite (the loop can be used in a path many times).

Input Format:
The first contains an integer t (1<=t<=10^4) — the number of test cases in the input. Then t test cases follow. Before each test case, there is an empty line.

The first line of the test case contains two integers n and m (1<=n<=4*10^5,0<=m<=4*10^5) — numbers of vertices and edges in graph respectively. The next m lines contain edges descriptions. Each line contains two integers a_i, b_i (1<=a_i,b_i<=n) — the start and the end of the i-th edge. The vertices of the graph are numbered from 1 to n. The given graph can contain loops (it is possible that a_i=b_i), but cannot contain multi-edges (it is not possible that a_i=a_j and b_i=b_j for inej).

The sum of n over all test cases does not exceed 4*10^5. Similarly, the sum of m over all test cases does not exceed 4*10^5.

Output Format:
Output t lines. The i-th line should contain an answer for the i-th test case: a sequence of n integers from -1 to 2.

Note:
None. Output only the code with no comments, explanation, or additional text.