Cod sursa(job #1609669)

Utilizator ris99Istrate Ruxandra ris99 Data 22 februarie 2016 22:24:13
Problema Floyd-Warshall/Roy-Floyd Scor 90
Compilator cpp Status done
Runda Arhiva educationala Marime 0.57 kb
#include <fstream>

using namespace std;
ifstream f("royfloyd.in");
ofstream g("royfloyd.out");
int n,a[105][105];
void citire()
{ int i,j;
  f>>n;
 for(i=1;i<=n;i++)
 for(j=1;j<=n;j++)
 f>>a[i][j];
}
void floyd()
{ int k,i,j;
  for(k=1;k<=n;k++)
  for(i=1;i<=n;i++)
  for(j=1;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 afis()
{ int i,j;
  for(i=1;i<=n;i++)
  {for(j=1;j<=n;j++)
   g<<a[i][j]<<" ";
   g<<endl;
  }
}
int main()
{
  citire();
  floyd();
  afis();
    return 0;
}