Pagini recente » Cod sursa (job #204059) | Cod sursa (job #2137232) | Cod sursa (job #2003853) | Cod sursa (job #847770) | Cod sursa (job #303345)
Cod sursa(job #303345)
#include <cstdio>
using namespace std;
#define FIN "royfloyd.in"
#define FOUT "royfloyd.out"
#define Nmax 101
int n;
int a[Nmax][Nmax];
inline void citire()
{
int i,j;
freopen(FIN,"r",stdin);
freopen(FOUT,"w",stdout);
scanf("%d", &n);
for (i=1;i<=n;++i)
for (j=1;j<=n;++j)
scanf("%d", &a[i][j]);
}
inline void rf()
{
int i,j,k;
for (k=1;k<=n;++k)
for (i=1;i<=n;++i)
for (j=1;j<=n;++j)
if (a[i][k] && a[k][j] && i!=j && (a[i][j]>a[i][k]+a[k][j] || a[i][j]==0))
a[i][j]=a[i][k]+a[k][j];
}
inline void scrie()
{
int i,j;
for (i=1;i<=n;++i)
{
for (j=1;j<=n;++j)
printf("%d ", a[i][j]);
printf("\n");
}
}
int main()
{
citire();
rf();
scrie();
fclose(stdin);
fclose(stdout);
return 0;
}