Pagini recente » Cod sursa (job #1913062) | Cod sursa (job #949836) | Cod sursa (job #671894) | Cod sursa (job #1862959) | Cod sursa (job #674460)
Cod sursa(job #674460)
#include <fstream>
using namespace std;
int n, m, ni, a[2000][2000], v[2000], vt[2000], nr, s[2000][2000];
bool p[2000];
ifstream fi("ctc.in");
ofstream fo("ctc.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.
DFS(i);// Continuam parcurgerea in adancime.
}
}
void DFSt (int nc) {
int i;
for (i = 1; i <= n; i++) // pentru fiecare nod
if (a[i][nc] == 1 and vt[i] == 0) {// i este vecin nevizitat al nodului curent?
vt[i] = 2;// Marcam i ca fiind vizitat.
DFSt(i);// Continuam parcurgerea in adancime.
}
}
int main() {
int i, j, 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; // Se actualizeaza matricea de adiacenta.
}
for (i = 1; i <= n; i++)
p[i] = true;
for (i = 1; i <= n; i++) {
if (p[i]) {
v[i] = 1; vt[i] = 2;
nr++; l = 0;
DFS(i);
DFSt(i);
for (j = 1; j <= n; j++)
if (v[j] + vt[j] == 3) {
l++; s[nr][l] = j; p[j] = false;
}
s[nr][0] = l;
for (j = 1; j <= n; j++)
v[j] = vt[j] = 0;
}
}
fo << nr << endl;
for (c = 1; c <= nr; c++) { // c - componenta
for (n = 1; n <= s[c][0]; n++) // n - nodul
fo << s[c][n] << ' ';
fo << endl;
}
return 0;
}