Pagini recente » Cod sursa (job #1086905) | Cod sursa (job #3278710) | Cod sursa (job #2508013) | Cod sursa (job #2061222) | Cod sursa (job #2084478)
#include <bits/stdc++.h>
#define infinit 1000000
using namespace std;
ifstream fin("royfloyd.in");
ofstream fout("royfloyd.out");
int i,j,n,d[105][105];
void Roy_Floyd();
int main()
{
fin >> n;
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
{
fin >> d[i][j];
if(d[i][j]==0)
d[i][j]=infinit;
}
Roy_Floyd();
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++)
{
if(d[i][j]!=infinit)
fout << d[i][j] << ' ';
else fout << '0' << ' ';
}
fout << '\n';
}
return 0;
}
void Roy_Floyd()
{
int i,j,k;
for(k=1;k<=n;k++)
{
for(i=1;i<=n;i++)
{
for(j=1;j<=n;j++)
{
if(d[i][j]!=infinit && i!=j)
d[i][j]=min(d[i][j],d[i][k]+d[k][j]);
}
}
}
}