Cod sursa(job #786184)

Utilizator juniorOvidiu Rosca junior Data 10 septembrie 2012 17:01:51
Problema Parcurgere DFS - componente conexe Scor 5
Compilator cpp Status done
Runda Arhiva educationala Marime 0.88 kb
#include <fstream>

using namespace std;

int n, m, ni, a[2000][2000], v[2000], nr;
//ifstream fi("df2.in");
//ofstream fo("df2.out");
ifstream fi("dfs.in");
ofstream fo("dfs.out");


void DFS (int nc) {
  int i;

  for (i = 1; i <= n; i++) // pentru fiecare nod
    if (a[nc][i] == 1 and v[i] == 0) {// i este vecin nevizitat al nodului curent?
      v[i] = 1;// Marcam i ca fiind vizitat.
      fo << i << ' ';
      DFS(i);// Continuam parcurgerea in adancime.
    }
}

int main() {
  int i, l, c;

  fi >> n >> m;  // Se citeste numarul de noduri si numarul de muchii.
  for (i = 1; i <= m; i++) {// Pentru fiecare muchie
    fi >> l >> c;// Se citesc informatiile despre o muchie.
    a[l][c] = 1; a[c][l] = 1;// Se actualizeaza matricea de adiacenta.
  }
  for (i = 1; i <= n; i++) {
    if (v[i] == 0) {
      v[i] = 1;
      nr++;
      DFS(i);
    }
  }
  fo << nr;
}

// 1 2 5
// 3 4 6