Cod sursa(job #278599)

Utilizator silaghi_raulSzilagyi Raul Razvan silaghi_raul Data 12 martie 2009 13:35:21
Problema Floyd-Warshall/Roy-Floyd Scor 90
Compilator cpp Status done
Runda Arhiva educationala Marime 0.72 kb
#include<stdio.h>
int a[100][100];
int n;
void citire()
{
  int i,j;
  FILE *in = fopen("royfloyd.in","rt");
  fscanf(in,"%d",&n);
  for(i=1;i<=n;i++)
   for(j=1;j<=n;j++)
    fscanf(in,"%d",&a[i][j]);
    
  fclose(in);
}
void royfloyd()
{
  int i,j,k;
  for(k=1;k<=n;k++)
   for(i=1;i<=n;i++)
    for(j=1;j<=n;j++)
    // daca avem muchie de la i->k si de la k->j 
     if (a[i][k] && a[k][j] && (a[i][j] > a[i][k] + a[k][j] || !a[i][j]) && i != j) 
      a[i][j] = a[i][k] + a[k][j];
}
int  main()
{
  int i,j;
  citire();
  royfloyd();
  FILE *out = fopen("royfloyd.out","wt");
  for(i=1;i<=n;i++)
  {
   for(j=1;j<=n;j++)
    fprintf(out,"%d ",a[i][j]);
   fprintf(out,"\n");
  }
  return 0;
}