Pagini recente » Cod sursa (job #2565121) | Cod sursa (job #2020695) | Cod sursa (job #249189) | Cod sursa (job #1136866) | Cod sursa (job #2546591)
#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;
}