Pagini recente » Cod sursa (job #891308) | Cod sursa (job #89574) | Cod sursa (job #2606965) | Cod sursa (job #1157151) | Cod sursa (job #1135419)
#include<iostream>
#include<fstream>
#define oo 1<<29
using namespace std;
int n,a[101][101];
inline void Citire()
{
int i,j;
freopen("royfloyd.in","r",stdin);
freopen("royfloyd.out","w",stdout);
scanf("%d",&n);
for (i=1;i<=n;i++)
for (j=1;j<=n;j++)
{
scanf("%d",&a[i][j]);
if (a[i][j]==0)
a[i][j]=oo;
}
}
inline void ROYFLOYD()
{
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][j]>a[i][k]+a[k][j])
a[i][j]=a[i][k]+a[k][j];
}
inline void Afisare()
{
int i,j;
for (i=1;i<=n;i++)
{
for (j=1;j<=n;j++)
{
if (i==j)
a[i][j]=0;
printf("%d ",a[i][j]);
}
printf("\n");
}
}
int main()
{
Citire();
ROYFLOYD();
Afisare();
return 0;
}