Cod sursa(job #278029)

Utilizator alexandru92alexandru alexandru92 Data 12 martie 2009 07:52:05
Problema Floyd-Warshall/Roy-Floyd Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.61 kb
#include<stdio.h>
int n,a[101][101];
void roy_floyd();
int main()
  {int i,j;
   freopen("royfloyd.in","rt",stdin);
   freopen("royfloyd.out","wt",stdout);
   scanf("%d",&n);
   for(i=1;i<=n;++i)
      for(j=1;j<=n;++j) scanf("%d",&a[i][j]);
   roy_floyd();
   for(i=1;i<=n;++i)
      {for(j=1;j<=n;++j) printf("%d ",a[i][j]);
       printf("\n");
      }
   return 0;
  }
void roy_floyd()
  {
   for(int k=1;k<=n;++k)
      for(int i=1;i<=n;++i)
         for(int j=1;j<=n;++j)
            if(a[i][j]>a[i][k]+a[k][j]&&a[i][k]&&a[j][k]&&i!=j||a[i][j]==0)
              a[i][j]=a[i][k]+a[k][j];
   }