Cod sursa(job #1423137)

Utilizator vtt271Vasile Toncu vtt271 Data 21 aprilie 2015 15:05:26
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.64 kb
#include <iostream>
#include <fstream>
#include <queue>
#include <string.h>

using namespace std;

#define MAX_DIM 100005
#define INF 20000000

std::vector <int> G[MAX_DIM];
int N, M;
int visit[MAX_DIM];

int explorare(int node)
{
	visit[node] = 1;
	for(int i = 0; i < G[node].size(); i++) 
		if( !visit[G[node][i]] ) explorare(G[node][i]);
}

int main()
{
	ifstream inFile("dfs.in");
	ofstream outFile("dfs.out");

	inFile >> N >> M;
	int x, y;
	for(int i = 1; i <= M; i++) {
		inFile >> x >> y;
		G[x].push_back(y);
		G[y].push_back(x);
	}
	
	int ct = 0;
	for(int i = 1; i <= N; i++) {
		if( !visit[i] ) {
			ct++;
			explorare(i);
		}
	}

	outFile << ct;

}