#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){
matrPond[i][j] = 0;
}
}*/
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(i != 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, N){
FOR(j, 1, N){
fprintf(out, "%d ", matrPond[i][j]);
}
fprintf(out, "\n");
}
fclose(in);
fclose(out);
return 0;
}