Cod sursa(job #1882382)

Utilizator stefan_gheorgheGheorghe Stefan stefan_gheorghe Data 17 februarie 2017 10:07:49
Problema Componente tare conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.97 kb
#include <fstream>
#include <vector>
using namespace std;
ifstream f("ctc.in");
ofstream g("ctc.out");
vector <int> m[100005],t[100005],s,r[100005];
int n, e, res, sel[100005], mark[100005];
void DFS(int node)
{
    sel[node] = 1;
    for(int i=0;i<m[node].size();i++)
        if(sel[m[node][i]]==0)
        DFS(m[node][i]);
    s.push_back(node);
}
void DFT(int node)
{
    mark[node]=res;
    r[res].push_back(node);
    for(int i=0;i<t[node].size();i++)
        if(mark[t[node][i]]==0)
            DFT(t[node][i]);
}
int main()
{int x,y;
    f>>n>>e;
    for(int i=1;i<=e;i++)
        f>>x>>y,m[x].push_back(y),t[y].push_back(x);
    for(int i=1;i<=n;i++)
        if(sel[i]==0)
        DFS(i);
    for(int i=s.size()-1;i>=0;i--)
        if(mark[s[i]]==0)
            ++res,DFT(s[i]);
    g <<res<<'\n';
    for(int i=1;i<=res;i++)
    {
        for(int j=0;j<r[i].size();j++)
            g<<r[i][j]<<' ';
        g<<'\n';
    }
    return 0;
}