Pagini recente » Cod sursa (job #505838) | Rating Vladucu Marius Emanuel (emimanu) | Cod sursa (job #1340658) | Cod sursa (job #2602308) | Cod sursa (job #1585422)
#include <stdio.h>
#define FOR(i, a, b) for (i = a; i <= b ; ++i)
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, N){
FOR(j, 1, N){
fscanf(in, "%d", &matrPond[i][j]);
}
}
FOR(k, 1, N){
FOR(i, 1, N){
FOR(j, 1, N){
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, N){
FOR(j, 1, N){
fprintf(out, "%d ", matrPond[i][j]);
}
fprintf(out, "\n");
}
fclose(in);
fclose(out);
return 0;
}