Cod sursa(job #2967991)

Utilizator apocal1ps13Stefan Oprea Antoniu apocal1ps13 Data 20 ianuarie 2023 15:49:54
Problema Componente tare conexe Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.02 kb
#include<vector>
#include<algorithm>
#include<fstream>
using namespace std;
ifstream cin("ctc.in");
ofstream cout("ctc.out");
const int NMAX = 1e5;
int n, m;
vector<int>g[NMAX + 1], gt[NMAX + 1], v, ans, ansr[NMAX + 1];
void dfs1(int node) {
	v[node] = 1;
	for (auto i : g[node])
		if (!v[i]) dfs1(i);
	ans.push_back(node);
}
void dfs2(int node, int k) {
	v[node] = k;
	ansr[k].push_back(node);
	for (auto i : gt[node])
		if (!v[i]) dfs2(i, k);
}
int main() {
	ios_base::sync_with_stdio(false);
	cin.tie(nullptr);
	cin >> n >> m;
	while (m--) {
		int u, v;
		cin >> u >> v;
		g[u].push_back(v);
		gt[v].push_back(u);
	}
	v = vector<int>(n + 1);

	for (int i = 1; i <= n; i++)
		if (!v[i]) dfs1(i);

	int ssc = 0;
	v = vector<int>(n + 1);
	reverse(ans.begin(), ans.end());

	for (auto i : ans)
		if (!v[i]) dfs2(i, ++ssc);

	cout << ssc << '\n';
	for (int i = 1; i <= ssc; i++) {
		sort(ansr[i].begin(), ansr[i].end());
		for (auto j : ansr[i]) cout << j << " ";
		cout << '\n';
	}
	return 0;
}