Cod sursa(job #1761700)

Utilizator dranoellenTurica Leonard-Petru dranoellen Data 22 septembrie 2016 18:51:26
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.96 kb
#include <iostream>
#include <fstream>
#include <vector>
#include <stack>
#include <cstring>
using namespace std;
vector <int> vec[100002];
vector <int>::iterator ii;
stack <int> st;
int m,n,unused[100002];
int main()
{
    ifstream fin ("dfs.in");
    ofstream fout ("dfs.out");
    fin>>n>>m;
    int i,x,y;
    memset(unused,0,sizeof(unused));
    for(i=0; i<m; ++i)
    {
        fin>>x>>y;
        vec[x].push_back(y);
        vec[y].push_back(x);
    }
    x=0,y=1;///x=nr de elem conexe
       while(y<=n)
    {
        ++x;
        st.push(y);
        unused[y]=1;

        while(!st.empty())
        {
            int a=st.top();
            st.pop();
            ii=vec[a].begin();
            while(ii!=vec[a].end())
            {
                if(!unused[*ii])
                    unused [*ii]=1,st.push(*ii);

                ++ii;
            }
        }

        while(unused[y])++y;
    }
    fout<<x;
    return 0;
}