Pagini recente » Cod sursa (job #2376640) | Cod sursa (job #1603826) | Profil CristinaMargh | Cod sursa (job #2822076) | Cod sursa (job #1382428)
#include <fstream>
#include <vector>
#define n_max 100002
using namespace std;
ifstream r("ctc.in");
ofstream w("ctc.out");
vector <int> g[n_max], gt[n_max], ctc[n_max];
int viz[n_max], top[n_max], k, n, m, nrc;
void df(int nod) {
viz[nod]=1;
for(vector <int>::iterator it=g[nod].begin(); it!=g[nod].end(); it++)
if (viz[*it]==0)
df(*it);
k++;
top[k]=nod;
}
void dft(int nod) {
viz[nod]=1;
for (vector <int>::iterator it=gt[nod].begin(); it!=gt[nod].end(); it++)
if (viz[*it]==0)
dft(*it);
ctc[nrc].push_back(nod);
}
void read() {
int i,j,k;
r>>n>>m;
for (k=0; k<m; k++) {
r>>i>>j;
g[i].push_back(j);
gt[j].push_back(i);
}
}
int main() {
read();
k=0;
for (int i=1; i<=n; i++)
if (viz[i]==0)
df(i);
for (int i=1; i<=n; i++)
viz[i]=0;
for (int i=k; i>=1; i--)
if (viz[top[i]]==0) {
nrc++;
dft(top[i]);
}
w<<nrc<<"\n";
for (int i=1; i<=nrc; i++) {
for (vector <int>::iterator it=ctc[i].begin(); it!=ctc[i].end(); it++)
w<<*it<<" ";
w<<"\n";
}
r.close();
w.close();
return 0;
}