Cod sursa(job #233821)

Utilizator free2infiltrateNezbeda Harald free2infiltrate Data 19 decembrie 2008 13:00:26
Problema Floyd-Warshall/Roy-Floyd Scor 20
Compilator cpp Status done
Runda Arhiva educationala Marime 0.78 kb
#include <stdio.h>

int A[257][257],B[257][257];

int main()
{
FILE *in = fopen("royfloyd.in","r");
FILE *out = fopen("royfloyd.out","w");

int n,i,j,k;

fscanf(in,"%d",&n);;

for (i=1;i<=n;i++)
for (j=1;j<=n;j++)
fscanf(in,"%d",&A[i][j]);

for (i=1;i<=n;i++)
for (j=1;j<=n;j++)
for (k=1;k<=n;k++)
if ((A[i][k]+A[k][j]<A[i][j] || A[i][j]==0) && i!=j && A[i][k] && A[k][j]) A[i][j]=A[i][k]+A[k][j];

/*
for (i=1;i<=n;i++)
for (j=1;j<=n;j++)
for (k=1;k<=n;k++)
if (A[i][k]+A[k][j]==A[i][j] && A[i][j]!=0) B[i][j]++;
*/



for (i=1;i<=n;i++)
{
for (j=1;j<=n;j++)
fprintf(out,"%d ",A[i][j]);
fprintf(out,"\n");
}

/*for (i=1;i<=n;i++)
{
for (j=1;j<=n;j++)
if (B[i][j]) fprintf(out,"%d ",B[i][j]-1);
else fprintf(out,"0 ");
fprintf(out,"\n");
}*/



}