Pagini recente » Cod sursa (job #2648027) | Cod sursa (job #781417) | Cod sursa (job #1431735) | Cod sursa (job #1451913) | Cod sursa (job #2039908)
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("royfloyd.in");
ofstream fout("royfloyd.out");
int main() {
int n;
fin>>n;
int mat[2][n][n];
for(int i = 0; i < n; ++i) {
for(int j = 0; j < n; ++j) {
fin>>mat[0][i][j];
}
}
for(int k = 0; k < n; ++k) {
int a = k % 2, b = (k + 1) % 2;
// cout<<k<<'\n';
// for(int i = 0; i < n; ++i) {
// for(int j = 0; j < n; ++j) {
// cout<<mat[a][i][j]<<' ';
// } cout<<'\n';
// } cout<<'\n';
for(int i = 0; i < n; ++i) {
for(int j = 0; j < n; ++j) {
// cout<<i<<' '<<j<<" "<<mat[a][i][j]<<" "<<mat[a][i][k] + mat[a][k][j]<<'\n';
if(mat[a][i][k] == 0 || mat[a][k][j] == 0 || i == j || i == k || j == k) mat[b][i][j] = mat[a][i][j];
mat[b][i][j] = min(mat[a][i][j], mat[a][i][k] + mat[a][k][j]);
}
} // cout<<'\n';
}
for(int i = 0; i < n; ++i) {
for(int j = 0; j < n; ++j) {
fout<<mat[n % 2][i][j]<<' ';
} fout<<'\n';
}
return 0;
}