Algorithm


E. Bertown roads
time limit per test
5 seconds
memory limit per test
256 megabytes
input
standard input
output
standard output

Bertown has n junctions and m bidirectional roads. We know that one can get from any junction to any other one by the existing roads.

As there were more and more cars in the city, traffic jams started to pose real problems. To deal with them the government decided to make the traffic one-directional on all the roads, thus easing down the traffic. Your task is to determine whether there is a way to make the traffic one-directional so that there still is the possibility to get from any junction to any other one. If the answer is positive, you should also find one of the possible ways to orient the roads.

Input

The first line contains two space-separated integers n and m (2 ≤ n ≤ 105, n - 1 ≤ m ≤ 3·105) which represent the number of junctions and the roads in the town correspondingly. Then follow m lines, each containing two numbers which describe the roads in the city. Each road is determined by two integers ai and bi (1 ≤ ai, bi ≤ n, ai ≠ bi) — the numbers of junctions it connects.

It is guaranteed that one can get from any junction to any other one along the existing bidirectional roads. Each road connects different junctions, there is no more than one road between each pair of junctions.

Output

If there's no solution, print the single number 0. Otherwise, print m lines each containing two integers pi and qi — each road's orientation. That is the traffic flow will move along a one-directional road from junction pi to junction qi. You can print the roads in any order. If there are several solutions to that problem, print any of them.

Examples
input
Copy
6 8
1 2
2 3
1 3
4 5
4 6
5 6
2 4
3 5
output
Copy
1 2
2 3
3 1
4 5
5 6
6 4
4 2
3 5
input
Copy
6 7
1 2
2 3
1 3
4 5
4 6
5 6
2 4
output
Copy
0

 

Code Examples

#1 Code Example with C++ Programming

Code - C++ Programming

#include <bits/stdc++.h>

using namespace std;

int const N = 1e5 + 1;
int n, m, idx[N], low[N], dfs, bridges;
bool vis[N];
set<pair<int, int> > st;
vector<vector<int> > g;

void DFS(int v, int p) {
	idx[v] = low[v] = dfs++;

	for(int i = 0, u; i < g[v].size(); ++i) {
		u = g[v][i];
		if(idx[u] == -1) {
			DFS(u, v);
			low[v] = min(low[v], low[u]);

			if(low[u] > idx[v])
				++bridges;
		} else if(u != p)
			low[v] = min(low[v], idx[u]);
	}
}

void print(int v, int p) {
	vis[v] = true;

	for(int i = 0, u; i < g[v].size(); ++i) {
		u = g[v][i];

		if(!vis[u]) {
			printf("%d %d\n", v + 1, u + 1);
			st.insert({v, u});
			st.insert({u, v});
			print(u, v);
		} else if(u != p && st.count({v, u}) == 0) {
			st.insert({v, u});
			st.insert({u, v});
			printf("%d %d\n", v + 1, u + 1);
		}
	}
}

int main() {
	scanf("%d %d", &n, &m);
	g.resize(n);
	for(int i = 0, a, b; i < m; ++i) {
		scanf("%d %d", &a, &b);
		--a, --b;
		g[a].push_back(b);
		swap(a, b);
		g[a].push_back(b);
	}

	memset(idx, -1, sizeof idx);
	DFS(0, -1);

	if(bridges > 0) {
		puts("0");
		return 0;
	}

	print(0, -1);

  return 0;
}
Copy The Code & Try With Live Editor

Input

x
+
cmd
6 8
1 2
2 3
1 3
4 5
4 6
5 6
2 4
3 5

Output

x
+
cmd
1 2
2 3
3 1
4 5
5 6
6 4
4 2
3 5
Advertisements

Demonstration


Codeforcess Solution Bertown roads, E. Bertown roads C,C++, Java, Js and Python ,Bertown roads,Codeforcess Solution

Previous
Codeforces solution 1080-B-B. Margarite and the best present codeforces solution
Next
CodeChef solution DETSCORE - Determine the Score CodeChef solution C,C+