Cod sursa(job #1881622)

Utilizator timar_andreiTimar Andrei timar_andrei Data 16 februarie 2017 17:01:54
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 1.13 kb
/**
Sa se determine numarul componentelor conexe ale grafului.

Date de intrare
Fisierul de intrare dfs.in contine pe prima linie numerele N si M cu semnificatia din enunt, iar pe urmatoarele M linii se gasesc cate doua numere X si Y cu
semnificatia: exista muchie de la nodul X la nodul Y.

Date de iesire
In fisierul de iesire dfs.out se va afisa numarul de componente conexe ale grafului.

Restrictii
1 <= N <= 100 000
0 <= M <= minim(200 000, N*(N+1)/2)
Pentru 50% dintre teste 1 <= N <= 1 000
*/
#include <iostream>
#include <fstream>
#include <vector>

using namespace std;

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

int N,M;
vector<int> G[100001];
int Use[100001];

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);
	}
}

void DFS(int nod)
{
	Use[nod] = 1;

	for(int i=0;i<G[nod].size();i++)
	{
		int vecin = G[nod][i];
		if (Use[vecin] == 0){
            DFS(vecin);
		}
	}
}

int main()
{
	Read();
	int c = 0;
	for(int i=1;i<=N;i++)
	{
		if (Use[i] == 0){
			c++;
			DFS(i);
		}
	}
	fout<<c;
	return 0;
}