Pagini recente » Cod sursa (job #276324) | Cod sursa (job #3238596) | Cod sursa (job #445567) | Cod sursa (job #1627409) | Cod sursa (job #745036)
Cod sursa(job #745036)
#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 i = 0; i < n; ++i) {
for(int j = 0; j < n; ++j) {
for(int k = 0; k < n; ++k) {
if((i == j) || (i == k) || (k == j))
continue;
if(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;
}