Cod sursa(job #1001828)

Utilizator deeaxtebanAndreea Teban deeaxteban Data 26 septembrie 2013 11:16:09
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.62 kb
using namespace std;
#include <iostream>
#include<vector>
#include <fstream>
#define NMAX 100005

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

vector <int> G[NMAX];
int N, M, use[NMAX] ;

void DFS(int nod)
{
	use[nod]=1;
	vector<int>::iterator it;
	for(it=G[nod].begin(); it!=G[nod].end(); it++)
	{
		if(!use[*it])
			DFS(*it);
	}
}
void Read()
{
	fin>>N>>M;
	for(int i=1; i<=M; i++)
	{
		int x, y;
		fin>>x>>y;
		G[x].push_back(y);
		G[y].push_back(x);
	}
}
int main()
{
	int nr=0, i;
	Read();
	for(i=1; i<=N; i++)
		if(!use[i])
		{
			DFS(i);
			nr++;
		}
	fout<<nr;
	return 0;
}