Pagini recente » Cod sursa (job #3336830) | Cod sursa (job #3344324) | Cod sursa (job #3334797) | Cod sursa (job #3344405) | Cod sursa (job #3344098)
#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];
int 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;
}