Pagini recente » Cod sursa (job #2956014) | Cod sursa (job #2174944) | Cod sursa (job #2492844) | Cod sursa (job #1024022) | Cod sursa (job #1533088)
#include <iostream>
#include <cstdio>
using namespace std;
int M[110][110],N;
int main()
{
freopen("royfloyd.in","r",stdin);
freopen("royfloyd.out","w",stdout);
scanf("%d",&N);
for(int i=1; i<=N; i++)
{
for(int j=1; j<=N; j++)
{
scanf("%d",&M[i][j]);
}
}
for(int k=1; k<=N; k++)
for(int i=1; i<=N; i++)
for(int j=1; j<=N; j++)
if(M[i][k]&&M[k][j])
if(i!=k&&j!=k&&j!=i)
if(M[i][k]+M[k][j]<M[i][j]||!M[i][j])
M[i][j]=M[i][k]+M[k][j];
for(int i=1; i<=N; i++)
{
for(int j=1; j<=N; j++)
{
printf("%d ",M[i][j]);
}
printf("\n");
}
return 0;
}