Pagini recente » Cod sursa (job #1898437) | Cod sursa (job #2055695) | Cod sursa (job #1571151) | Cod sursa (job #542724) | Cod sursa (job #2343530)
#include <fstream>
#define MAX 1010
#define MAX1 101000
using namespace std;
ifstream fin("royfloyd.in");
ofstream fout("royfloyd.out");
int cost[MAX][MAX];
int n;
void citire();
void rf();
void afisare();
int main()
{
citire();
rf();
afisare();
return 0;
}
void citire()
{
int i, j;
for(i=1; i<=n; i++)
for(j=1; j<=n; j++)
cost[i][j] = MAX1;
fin >> n;
for(i=1; i<=n; i++)
for(j=1; j<=n; j++)
fin >> cost[i][j];
}
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(k!=i && k!=j && i!=j)
cost[i][j] = min(cost[i][j], cost[i][k] + cost[k][j]);
}
void afisare()
{
int i,j;
for(i=1; i<=n; i++)
{
for(j=1; j<=n; j++)
if(cost[i][j] == MAX1)
fout<< 0 << ' ';
else fout << cost[i][j] << ' ';
fout<<'\n';
}
}