Pagini recente » Cod sursa (job #1776124) | Cod sursa (job #1529038) | Cod sursa (job #1534092) | Cod sursa (job #303071) | Cod sursa (job #2499064)
#include <cstdio>
#include <vector>
#include <queue>
#include <algorithm>
using namespace std;
int n,d[103][103];
int main () {
freopen("royfloyd.in","r",stdin);
freopen("royfloyd.out","w",stdout);
scanf("%d", &n);
for(int i=1;i<=n;++i)
for(int j=1;j<=n;++j) {
scanf("%d", &d[i][j]);
}
for(int k=1;k<=n;++k)
for(int i=1;i<=n;++i)
for(int j=1;j<=n;++j)
if(i!=j && j!=k && i!=k) {
if(d[i][j]==0 && d[i][k]!=0 && d[k][i]!=0)
d[i][j]=d[i][k]+d[k][i];
else if(d[i][j]>d[i][k]+d[k][j] && d[i][j]!=0 && d[i][k]!=0 && d[k][j]!=0)
d[i][j]=d[i][k]+d[k][j];
}
for(int i=1;i<=n;++i) {
for(int j=1;j<=n;++j)
printf("%d ", d[i][j]);
printf("\n");
}
return 0;
}