Cod sursa(job #732271)

Utilizator Stefex09Stefan Teodorescu Stefex09 Data 9 aprilie 2012 23:19:06
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.57 kb
#include<iostream>
#include<fstream>
#include<vector>

using namespace std;

#define maxn 100010

ifstream in("dfs.in");
ofstream out("dfs.out");

vector <int> graf[maxn];
char f[maxn];

void dfs(int x)
{
	int i;
	f[x]=1;
	for(vector<int>::iterator it = graf[x].begin();it!=graf[x].end();it++)
		if(!f[*it])
			dfs(*it);
}

int main()
{
	int i,n,m,nr=0,nod1,nod2;
	in>>n>>m;
	for(i=1;i<=m;i++){
		in>>nod1>>nod2;
		graf[nod1].push_back(nod2);
		graf[nod2].push_back(nod1);
	}
	for(i=1;i<=n;i++)
		if(!f[i])
			++nr,dfs(i);
	out<<nr;
	return 0;
}