Cod sursa(job #1735403)

Utilizator MickeyTurcu Gabriel Mickey Data 29 iulie 2016 18:57:50
Problema Parcurgere DFS - componente conexe Scor 5
Compilator cpp Status done
Runda Arhiva educationala Marime 0.76 kb
#include<fstream>
#include<string.h>
#include<ctype.h>
#include<iostream>
#include<algorithm>
#include<map>
#include<unordered_map>
#include<array>
#include<deque>
#include<unordered_set>
using namespace std;
vector <int> v[100001];
vector <int> ::iterator it;
deque <int> deq;
int n, m, i, start, finish, nr, j, el;
bool viz[100001];
void dfs(int node)
{
	viz[node] = 1;
	if(v[node].size()!=0)
	for (it = v[node].begin(); it != v[node].end(); it++)
		dfs(*it);
}
int main()
{
	ifstream f("dfs.in");
	ofstream g("dfs.out");
	f >> n >> m;
	for (i = 1; i <= m; i++)
	{
		f >> start >> finish;
		v[start].push_back(finish);
	}
	nr = 0;
	for (i = 1; i <= n; i++)
	{
		if (viz[i] == 0)
		{
			dfs(i);
			nr++;
		}
	}
	g << nr;
	return 0;
}