Pagini recente » Cod sursa (job #785892) | Cod sursa (job #1079355) | Cod sursa (job #2580470) | Cod sursa (job #639990) | Cod sursa (job #1448231)
#include <fstream>
#define inf 2000005
using namespace std;
int dist[105][105];
int main()
{
ifstream cin("royfloyd.in");
ofstream cout("royfloyd.out");
int n = 0;
cin >> n;
int j;
for (int i = 1; i <= n; i++)
for (j = 1; j <= n; j++)
cin >> dist[i][j];
for (int i = 1; i <= n; i++)
for (j = 1; j <= n; j++)
if (!dist[i][j])
dist[i][j] = inf;
int i, k;
for (k = 1; k <= n; k++)
for (i = 1; i <= n; i++)
for (j = 1; j <= n; j++)
if (i != j && dist[i][k] + dist[k][j] < dist[i][j])
dist[i][j] = dist[i][k] + dist[k][j];
for (i = 1; i <= n; i++)
dist[i][i] = 0;
for (i = 1; i <= n; i++)
for (j = 1; j <= n; j++)
cout << dist[i][j] << " \n"[j == n];
cin.close();
cout.close();
return 0;
}