Cod sursa(job #2791345)

Utilizator bogdan2405Strat Bogdan-Valentin bogdan2405 Data 30 octombrie 2021 13:15:36
Problema Parcurgere DFS - componente conexe Scor 85
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.95 kb
#include<bits/stdc++.h>

using namespace std;

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

vector<int> freq;
map<int,vector<int>> adjList;

/*int sumFreq(vector<int> &freq){
    int sum=0;
    int i;
    for(i=0;i<freq.size();++i)
        sum+=freq[i];

    return sum;
}*/

void DFS(int x){
    int i;

    for(i=0;i<adjList[x].size();++i){
        if(freq[adjList[x][i]-1]==0){
            freq[adjList[x][i]-1]++;
            //cout<<adjList[x][i]<<' ';
            DFS(adjList[x][i]);
        }
        
    }
}
int main(){
    int n,m,a,b,count=0;
    
    int i,j;
    f>>n>>m;
    for(i=0;i<m;++i){
        f>>a>>b;
        adjList[a].push_back(b);
        adjList[b].push_back(a);
    }

    for(i=0;i<n;++i){
        freq.push_back(0);
    }
        for(i=0;i<freq.size();++i){
            if(freq[i]==0){
                freq[i]++;
                count++;
                DFS(i+1);
            }
                
        }
    

    g<<count;
    return 0;
}