Virtual contest is a way to take part in past contest, as close as possible to participation on time. It is supported only ACM-ICPC mode for virtual contests.
If you've seen these problems, a virtual contest is not for you - solve these problems in the archive.
If you just want to solve some problem from a contest, a virtual contest is not for you - solve this problem in the archive.
Never use someone else's code, read the tutorials or communicate with other person during a virtual contest.

No tag edit access

C. Flawed Flow

time limit per test

2 secondsmemory limit per test

256 megabytesinput

standard inputoutput

standard outputEmuskald considers himself a master of flow algorithms. Now he has completed his most ingenious program yet — it calculates the maximum flow in an undirected graph. The graph consists of *n* vertices and *m* edges. Vertices are numbered from 1 to *n*. Vertices 1 and *n* being the source and the sink respectively.

However, his max-flow algorithm seems to have a little flaw — it only finds the flow volume for each edge, but not its direction. Help him find for each edge the direction of the flow through this edges. Note, that the resulting flow should be correct maximum flow.

More formally. You are given an undirected graph. For each it's undirected edge (*a*_{i}, *b*_{i}) you are given the flow volume *c*_{i}. You should direct all edges in such way that the following conditions hold:

- for each vertex
*v*(1 <*v*<*n*), sum of*c*_{i}of incoming edges is equal to the sum of*c*_{i}of outcoming edges; - vertex with number 1 has no incoming edges;
- the obtained directed graph does not have cycles.

Input

The first line of input contains two space-separated integers *n* and *m* (2 ≤ *n* ≤ 2·10^{5}, *n* - 1 ≤ *m* ≤ 2·10^{5}), the number of vertices and edges in the graph. The following *m* lines contain three space-separated integers *a*_{i}, *b*_{i} and *c*_{i} (1 ≤ *a*_{i}, *b*_{i} ≤ *n*, *a*_{i} ≠ *b*_{i}, 1 ≤ *c*_{i} ≤ 10^{4}), which means that there is an undirected edge from *a*_{i} to *b*_{i} with flow volume *c*_{i}.

It is guaranteed that there are no two edges connecting the same vertices; the given graph is connected; a solution always exists.

Output

Output *m* lines, each containing one integer *d*_{i}, which should be 0 if the direction of the *i*-th edge is *a*_{i} → *b*_{i} (the flow goes from vertex *a*_{i} to vertex *b*_{i}) and should be 1 otherwise. The edges are numbered from 1 to *m* in the order they are given in the input.

If there are several solutions you can print any of them.

Examples

Input

3 3

3 2 10

1 2 10

3 1 5

Output

1

0

1

Input

4 5

1 2 10

1 3 10

2 3 5

4 2 15

3 4 5

Output

0

0

1

1

0

Note

In the first test case, 10 flow units pass through path , and 5 flow units pass directly from source to sink: .

Codeforces (c) Copyright 2010-2019 Mike Mirzayanov

The only programming contests Web 2.0 platform

Server time: Apr/22/2019 04:12:18 (g1).

Desktop version, switch to mobile version.

Supported by

User lists

Name |
---|