Cod sursa(job #2546591)

Utilizator MoldovanAndrei1Moldovan Andrei MoldovanAndrei1 Data 14 februarie 2020 12:01:08
Problema Componente tare conexe Scor 40
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.99 kb
#include <bits/stdc++.h>
using namespace std;
vector<int>v[100005];
vector<int>g[100005];
int n1;
bitset<100005>fr;
int s[100005];
void dfs(int nod)
{
    fr[nod]=1;
    int i;
    for(i=0;i<v[nod].size();i++)
    {
        int ve=v[nod][i];
        if(!fr[ve])dfs(ve);
    }
    s[n1]=nod;
    --n1;
}
int fr1[100005];
void dfs1(int nod)
{
    fr1[nod]=1;
    int i;
    for(i=0;i<g[nod].size();i++)
    {
        int ve=g[nod][i];
        if(!fr1[ve])dfs1(ve);
    }
}
int main()
{
    freopen("ctc.in","r",stdin);
    freopen("ctc.out","w",stdout);
    int n,m,i,a,b;
    scanf("%d%d",&n,&m);
    n1=n;
    for(i=1;i<=m;i++)
    {
        scanf("%d%d",&a,&b);
        v[a].push_back(b);
        g[b].push_back(a);
    }
    for(i=1;i<=n;i++)
    {
       if(fr[i]==0)dfs(i);
    }
    int cnt=0;
    for(i=1;i<=n;i++)
    {
        if(!fr1[s[i]])
        {
            dfs1(s[i]);
            cnt++;
        }
    }
    cout<<cnt;
    return 0;
}