Cod sursa(job #3310716)

Utilizator tudorvoieVoie Tudor tudorvoie Data 16 septembrie 2025 09:44:15
Problema Componente tare conexe Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.88 kb
#include <bits/stdc++.h>
using namespace std;

ifstream fin("ctc.in");
ofstream fout("ctc.out");

int n, m;
vector<int> g[100001], gt[100001], afis[100001];

int vizitat[100001], cnt = 0;
stack<int> st;

void dfs(int x) {
	vizitat[x] = 1;
	for(auto i : g[x]) {
		if(!vizitat[i]) {
			dfs(i);
		}
	}
	st.push(x);
}

void dfs2(int x) {
	vizitat[x] = 2;
	afis[cnt].push_back(x);

	for(auto i : gt[x]) {
		if(vizitat[i] == 1) 
		{
			dfs2(i);
		}
	}
}

int main(){
	fin >> n >> m;
	for(int i = 1; i <= m; i++) {
		int a, b;
		fin >> a >> b;
		g[a].push_back(b);
		gt[b].push_back(a);
	}
	
	for(int i = 1; i <= n; i++) {
		if(!vizitat[i]) {
			dfs(i);
		}
	}

	while(!st.empty()) {
		int acuma = st.top();
		st.pop();
		if(vizitat[acuma] == 1) {
			cnt++;
			dfs2(acuma);
		}
	}

	fout << cnt << '\n';
	for(int i = 1; i <= cnt; i++) {
		for(auto j : afis[i]) {
			fout << j << " ";
		}
		fout << '\n';
	}
}