Pagini recente » Cod sursa (job #1027144) | Cod sursa (job #2866668) | Cod sursa (job #151207) | Cod sursa (job #2568092) | Cod sursa (job #2364684)
#include <iostream>
#include <fstream>
#include <list>
#include <algorithm>
using namespace std;
ifstream fin("dfs.in");
ofstream fout("dfs.out");
list<int> G[100005];
int n,m;
int viz[100005];
void DFS(int k)
{
viz[k]=1;
for(int i=1;i<=n;i++)
if(count(G[k].begin(),G[k].end(),i))
DFS(i);
}
int main()
{
int nr_conex=0;
int i,j;
fin>>n>>m;
while(fin>>i>>j)
G[i].push_front(j);
for(int i=1;i<=n;i++){
if(!viz[i])
nr_conex++;
DFS(i);
}
fout<<nr_conex;
}