Pagini recente » Cod sursa (job #3231181) | Cod sursa (job #2581658) | Cod sursa (job #2886059) | Cod sursa (job #2931507) | Cod sursa (job #727474)
Cod sursa(job #727474)
#include <cstdio>
#include <cstdlib>
#include <cmath>
using namespace std;
long a[101][101];
int n;
void read_input()
{
int i,j;
scanf("%i", &n);
for(i=0;i<n;i++) for(j=0;j<n;j++) scanf("%ld", &a[i][j]);
}
void roy_floyd()
{
int k,i,j;
for(k=0;k<n;k++) for(i=0;i<n;i++) for(j=0;j<n;j++) if(a[i][k] && a[k][j] && (a[i][k]+a[k][j]<a[i][j] || !a[i][j]) && i!=j) a[i][j]=a[i][k]+a[k][j];
}
void write_output()
{
int i,j;
for(i=0;i<n;i++)
{
for(j=0;j<n;j++) printf("%ld ", a[i][j]);
printf("\n");
}
}
int main()
{
freopen("royfloyd.in","r",stdin);
freopen("royfloyd.out","w",stdout);
int i;
read_input();
roy_floyd();
write_output();
scanf("%i", &i);
return 0;
}