Pagini recente » Cod sursa (job #2499497) | Cod sursa (job #816347) | Cod sursa (job #2829187)
#include <iostream>
#include <fstream>
#define infinit 100000
using namespace std;
ifstream fin ("royfloyd.in");
ofstream fout ("royfloyd.out");
int n, ma[110][110];
void afisareMa()
{
for(int i = 1; i <= n; i++)
{
for(int j = 1; j <= n; j++)
fout << ma[i][j] << ' ';
fout << endl;
}
}
void royFloyd()
{
int i, j, k;
for(int k = 1; k <= n; k++)
for(int i = 1; i <= n; i++)
for(int j = 1; j <= n; j++)
if(ma[i][k] != infinit && ma[k][j] != infinit)
if(ma[i][j] > ma[i][k] + ma[k][j])
ma[i][j] = ma[i][k] + ma[k][j];
}
int main()
{
fin >> n;
for(int i = 1; i <= n; i++)
for(int j = 1; j <= n; j++)
{
fin >> ma[i][j];
if(i != j && ma[i][j] == 0)
ma[i][j] = infinit;
}
royFloyd();
afisareMa();
return 0;
}