Cod sursa(job #893706)

Utilizator harababurelPuscas Sergiu harababurel Data 26 februarie 2013 17:22:30
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.67 kb
#include <iostream>
#include <fstream>
#include <vector>
#include <string.h>
#define nmax 100005
using namespace std;

vector <int> vecin[nmax];
bool vizitat[nmax];

void dfs(int curent) {
	for(int i = 0; i < vecin[curent].size(); i++)
		if(!vizitat[vecin[curent][i]]) {
			vizitat[vecin[curent][i]] = true;
			dfs(vecin[curent][i]);
		}
}

int main() {
	ifstream f("dfs.in");
	ofstream g("dfs.out");

	memset(vizitat, 0, nmax*sizeof(bool));
	int n, m;

	f>>n>>m;
	for(int i=1; i<=m; i++) {
		int a, b;
		f>>a>>b;
		vecin[a].push_back(b);
		vecin[b].push_back(a);
	}

	int sol = 0;
	for(int i=1; i<=n; i++)
		if(!vizitat[i]) {
			dfs(i);
			sol++;
		}

	g<<sol<<"\n";

	return 0;
}