Pagini recente » Cod sursa (job #543837) | Cod sursa (job #2032597) | Cod sursa (job #636681) | Cod sursa (job #354230) | Cod sursa (job #2053506)
#include <fstream>
using namespace std;
ifstream cin ("royfloyd.in");
ofstream cout ("royfloyd.out");
int n;
int mat[105][105];
int main() {
ios::sync_with_stdio(false);
cin.tie(NULL);
cin>>n;
const int inf = 2e9;
for (int i=1; i<=n; i++){
for (int j=1; j<=n; j++){
cin>>mat[i][j];
if (mat[i][j] == 0){
mat[i][j] = inf;
}
}
}
for (int k=1; k<=n; k++){
for (int i=1; i<=n; i++){
if (k == i || mat[i][k] == inf){
continue;
}
for (int j=1; j<=n; j++){
if (i == j || mat[k][j] == inf){
continue;
}
mat[i][j] = min (mat[i][j] , mat[i][k] + mat[k][j]);
}
}
}
for (int i=1; i<=n; i++){
for (int j=1; j<=n; j++){
if (mat[i][j] == inf){
mat[i][j] = 0;
}
cout<<mat[i][j]<<" ";
}
cout<<'\n';
}
return 0;
}