Pagini recente » Istoria paginii utilizator/alexdm | Istoria paginii utilizator/darius215 | Istoria paginii utilizator/apyr_geo | Diferente pentru utilizator/iunia_bujita intre reviziile 2 si 1 | Cod sursa (job #1585440)
#include <stdio.h>
int main(){
FILE *in, *out;
in = fopen("royfloyd.in", "r");
out = fopen("royfloyd.out", "w");
int n, i, j, k;
fscanf(in, "%d", &n);
int matrPond[n][n];
for(i = 1; i <= n; i++){
for(j = 1; j <= n; j++){
fscanf(in, "%d", &matrPond[i][j]);
}
}
for(k = 1; k <= n; k++){
for(i = 1; i <= n; i++){
for(j = 1; j <= n; j++){
if(matrPond[i][k] && matrPond[k][j] &&
(matrPond[i][j] > matrPond[i][k] + matrPond[k][j] || !matrPond[i][j])
&& i != j)
matrPond[i][j] = matrPond[i][k] + matrPond[k][j];
}
}
}
for(i = 1; i <= n; i++){
for(j = 1; j <= n; j++){
fprintf(out, "%d ", matrPond[i][j]);
}
fprintf(out, "\n");
}
fclose(in);
fclose(out);
return 0;
}