Cod sursa(job #157401)

Utilizator NightRavenBogdan Tanasoiu NightRaven Data 12 martie 2008 23:45:31
Problema Floyd-Warshall/Roy-Floyd Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.66 kb
#include <fstream>
#include <iostream>
using namespace std;
int main()
{
    fstream f("royfloyd.in",ios::in);
    int n;
    f>>n;
    int a[n][n],i,j,k;
    for (i=1; i<=n; i++)
        for (j=1; j<=n; j++) f>>a[i][j];
    f.close();
    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][j] > a[i][k] + a[k][j] || (i != j && !a[i][j])))
                     a[i][j] = a[i][k] + a[k][j];
    fstream f2("royfloyd.out",ios::out);
        for (i=1; i<=n; i++)
        {
            for (j=1; j<=n; j++) f2<<a[i][j]<<" ";
            f2<<endl;
        }
    f2.close();
}