Pagini recente » Cod sursa (job #1244481) | Cod sursa (job #3300735) | Cod sursa (job #2990750) | Cod sursa (job #3342402) | Cod sursa (job #3344099)
#include <bits/stdc++.h>
using namespace std;
#define pii pair<int,int>
#define ll long long
const int NMAX = 100;
int mat[NMAX+1][NMAX+1];
long long dp[NMAX+1][NMAX+1];
int n;
void read(){
cin >> n;
for(int i = 1; i <= n; i++)
for(int j = 1; j <= n; j++)
cin >> mat[i][j];
}
void solve(){
for(int i = 1; i <= n; i++)
for(int j = 1; j <= n; j++){
if(i == j)
dp[i][j] = 0;
else if(mat[i][j] == 0)
dp[i][j] = INT_MAX;
else
dp[i][j] = mat[i][j];
}
for(int k = 1; k <= n; k++){
for(int i = 1; i <= n; i++){
if(dp[i][k] == INT_MAX)
continue;
for(int j = 1; j <= n; j++){
if(dp[j][k] == INT_MAX)
continue;
dp[i][j] = min(dp[i][j],dp[i][k] + dp[k][j]);
}
}
}
for(int i = 1; i <=n; i++){
for(int j =1; j <= n; j++)
cout << dp[i][j] << ' ';
cout << '\n';
}
}
int main() {
freopen("royfloyd.in","r",stdin);
freopen("royfloyd.out","w",stdout);
read();
solve();
return 0;
}