Cod sursa(job #208404)

Utilizator alex23alexandru andronache alex23 Data 16 septembrie 2008 11:51:59
Problema Floyd-Warshall/Roy-Floyd Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.65 kb
#include <stdio.h>


 int main()
  {FILE *f;
   int a[101][101],n,i,j,k;

   f=fopen("royfloyd.in","r");
   fscanf(f,"%d",&n);
   for (i=1;i<=n;i++)
     for (j=1;j<=n;j++)
         fscanf(f,"%d",&a[i][j]);
   fclose(f);

   for (i=1;i<=n;i++)
     for (j=1;j<=n;j++)
         if (!a[i][j]) a[i][j] = 2000;   
   

   for (k=1;k<=n;k++)
      for (i=1;i<=n;i++)
        for (j=1;j<=n;j++)
         if (a[i][j] > a[i][k] + a[k][j]) a[i][j] = a[i][k] + a[k][j];

   f=fopen("royfloyd.out","w");
   for (i=1;i<=n;i++)
      {for (j=1;j<=n;j++)
           fprintf(f,"%d ",a[i][j]);
        fprintf(f,"\n");
        }
   fclose(f);

   }