Pagini recente » Cod sursa (job #1934067) | Cod sursa (job #692752) | Cod sursa (job #1207206) | Cod sursa (job #1724987) | Cod sursa (job #1883925)
#include <iostream>
#include <cstdio>
#define NMAX 105
using namespace std;
int graf[NMAX][NMAX];
int N;
void citire()
{
scanf("%d\n",&N);
for(int i=1; i<=N; i++)
for(int j=1; j<=N; j++)
scanf("%d",*(graf+i)+j);
}
void rf()
{
for(int k=1; k<=N; k++)
for(int i=1; i<=N; i++)
for(int j=1; j<=N; j++)
if(graf[i][k]&&graf[k][j])
if(i!=j && j!=k && k!=i)
if(graf[i][k]+graf[k][j] < graf[i][j] || graf[i][j]==0)
graf[i][j]=graf[i][k]+graf[k][j];
}
void afisare()
{
for(int i=1; i<=N; i++)
{
for(int j=1; j<=N; j++)
printf("%d ",graf[i][j]);
printf("\n");
}
}
int main()
{
freopen("royfloyd.in","r",stdin);
freopen("royfloyd.out","w",stdout);
citire();
rf();
afisare();
return 0;
}