Pagini recente » Cod sursa (job #1935203) | Cod sursa (job #2115471) | Cod sursa (job #606362) | Cod sursa (job #2644293) | Cod sursa (job #2208847)
#include <iostream>
#include <fstream>
using namespace std;
ifstream fin("royfloyd.in");
ofstream fout("royfloyd.out");
int N;
int dist[101][101];
void Read(void)
{
fin >> N;
for (int i = 0; i < N; i++)
{
for (int j = 0; j < N; j++)
{
fin >> dist[i][j];
}
}
}
void Floyd_Warshall(void)
{
for (int k = 0; k < N; k++)
{
for (int i = 0; i < N; i++)
{
for (int j = 0; j < N; j++)
{
if (dist[i][k] && dist[k][j] && (dist[i][j] > dist[i][k] + dist[k][j] || !dist[i][j]) && i != j)
{
dist[i][j] = dist[i][k] + dist[k][j];
}
}
}
}
}
void Print(void)
{
for (int i = 0; i < N; i++)
{
for (int j = 0; j < N; j++)
{
fout << dist[i][j] << ' ';
}
fout << "\n";
}
}
int main(void)
{
Read();
Floyd_Warshall();
Print();
return 0;
}