Cod sursa(job #473221)

Utilizator giuliastefGiulia Stef giuliastef Data 28 iulie 2010 14:06:32
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.74 kb
//Roy-Floyd/Floyd-Warshall

#include <fstream>
using namespace std;
int n,a[101][101];
void citire()
{
     ifstream f("royfloyd.in");
     f>>n;
     for(int i=1;i<=n;i++)
      for(int j=1;j<=n;j++)
              f>>a[i][j];
     f.close();
}

void royfloyd()
{
     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];
}

void afisare()
{
     ofstream g("royfloyd.out");
     for(int i=1;i<=n;i++)
     {
      for(int j=1;j<=n;j++)
       g<<a[i][j]<<" ";
      g<<"\n";
     }
     g.close();
}

int main()
{
    citire();
    royfloyd();
    afisare();
    return 0;
}