Cod sursa(job #1535469)

Utilizator BogdanVMVilculescu Mihai Bogdan BogdanVM Data 24 noiembrie 2015 20:04:00
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.62 kb
#include <iostream>
#include <fstream>

using namespace std;

int n, a[102][102];

ifstream f("royfloyd.in");
ofstream g("royfloyd.out");

void rf()
{
    for(int k=1;k<=n;k++)
     for(int i=1;i<=n;i++)
      for(int j=1;j<=n;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()
{
   f>>n;
   for(int i=1;i<=n;i++)
      for(int j=1;j<=n;j++)
        f>>a[i][j];

   rf();

   for(int i=1;i<=n;i++)
   {
       for(int j=1;j<=n;j++)
        g<<a[i][j]<<" ";
       g<<'\n';
   }

   f.close();
   g.close();
}