Pagini recente » Cod sursa (job #46235) | Cod sursa (job #536843) | Cod sursa (job #2359607) | Cod sursa (job #2839927) | Cod sursa (job #2788038)
#include<iostream>
#include<fstream>
#include<vector>
using namespace std;
const int maxim = 100002;
int n, m, intersectie[maxim], vizitate[maxim], componente[maxim], nrComp = 0;
vector<int> a[maxim], transpus[maxim];
ifstream in("ctc.in");
ofstream out("ctc.out");
void citireOrientat(){
int x, y;
in >> n >> m;
for(int i = 1; i <= m; i++){
in >> x >> y;
a[x].push_back(y);
transpus[y].push_back(x); //formez graful transpus
}
}
void dfs(int x, vector<int> graf[maxim]){
vizitate[x] = 1;
for(auto j: graf[x])
if(vizitate[j] == 0)
dfs(j, graf);
}
//
//void dfsTranspus(int x){
// vizitate[x] = 1;
// for(auto j: transpus[x])
// if(vizitate[j] == 0)
// dfsTranspus(j);
//}
int main(){
citireOrientat();
vector<int> ctcActual;
for(int i = 1; i <= n; i++){
if(componente[i] == 0){
dfs(i, a);
nrComp++;
for(int x = 1; x <= n; x++){
intersectie[x] += vizitate[x];
vizitate[x] = 0;
}
dfs(i, transpus);
for(int x = 1; x <= n; x++){
intersectie[x] += vizitate[x];
vizitate[x] = 0;
}
for(int x = 1; x <= n; x++){
if(intersectie[x] == 2)
componente[x] = nrComp;
intersectie[x] = 0;
}
}
}
out << nrComp << "\n";
for(int i = 1; i <= nrComp; i++){
for(int j = 1; j <= n; j++)
if(componente[j] == i)
out << j << " ";
out << "\n";
}
return 0;
}