Cod sursa(job #3354759)

Utilizator andrei_335Stancu Andrei-Mihai andrei_335 Data 20 mai 2026 11:48:59
Problema Parcurgere DFS - componente conexe Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.84 kb
#include <bits/stdc++.h>

using namespace std;

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

void dfs(int node, int n, vector<vector<int>> &adj, vector<int> &vizitat) {
    if (!vizitat[node]) {
        vizitat[node] = true;
        for(int neigh : adj[node])
            dfs(neigh, n, adj, vizitat);
    }
}

int main()
{
    int n, m;
    fin >> n >> m;
    vector<vector<int>> adj(n + 1);
    for (int i = 0; i < m; i++) {
        int u, v;
        fin >> u >> v;
        adj[u].push_back(v);
        adj[v].push_back(u);
    }
    vector<int> vizitat(n + 1, 0);
    int nr_ccx = 0;
    vector<int> rezultat(n + 1);
    stack<int> st;
    for (int i = 1; i <= n; i++) {
        if (vizitat[i])
            continue;
        nr_ccx++;
        dfs(i, n, adj, vizitat);
    }
    fout << nr_ccx << endl;
    return 0;
}