Cod sursa(job #1248897)

Utilizator bogdanboboc97Bogdan Boboc bogdanboboc97 Data 26 octombrie 2014 10:55:27
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.64 kb
#include <fstream>
#include <vector>

using namespace std;

ifstream cin("dfs.in");
ofstream cout("dfs.out");

vector< vector<int> > a;
vector<bool>v;
int n;

void dfs(int x)
{
    for(vector<int>::iterator i=a[x].begin();i!=a[x].end();++i)
    if(v[*i]==false)
    {
        v[*i]=true;
        dfs(*i);
    }
}

int main()
{
    int i,c=0,x,y,m;
    cin>>n>>m;
    a=vector< vector<int> >(n+1);
    v=vector<bool>(n+1);
    for(;m;m--)
    {
        cin>>x>>y;
        a[x].push_back(y);
        a[y].push_back(x);
    }
    for(i=1;i<=n;i++)
    if(v[i]==false)
    {
        v[i]=true;
        dfs(i);
        c++;
    }
    cout<<c;
    return 0;
}