Pagini recente » Cod sursa (job #1446344) | Cod sursa (job #2579300) | Cod sursa (job #2952209) | Cod sursa (job #2229724) | Cod sursa (job #745039)
Cod sursa(job #745039)
#include <cstdio>
int main(void) {
int **a;
int n;
FILE *in = fopen("royfloyd.in", "r");
FILE *out = fopen("royfloyd.out", "w");
fscanf(in, "%d", &n);
a = new int*[n + 1];
for(int i = 0; i < n; ++i) {
a[i] = new int[n];
for(int j = 0; j < n; ++j) {
fscanf(in, "%d", &a[i][j]);
}
}
for(int k = 0; k < n; ++k) {
for(int i = 0; i < n; ++i) {
for(int j = 0; j < n; ++j) {
if((i == j) || (i == k) || (k == j))
continue;
if(a[i][k] && a[k][j] && (a[i][j] > a[i][k] + a[k][j] || !a[i][j]))
a[i][j] = a[i][k] + a[k][j];
}
}
}
for(int i = 0; i < n; ++i) {
for(int j = 0; j < n; ++j) {
fprintf(out, "%d ", a[i][j]);
}
fprintf(out, "\n");
}
fclose(in);
fclose(out);
return 0;
}