Cod sursa(job #1645714)

Utilizator andrei_bB. Andrei andrei_b Data 10 martie 2016 13:25:13
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.65 kb
#include <fstream>

using namespace std;

ifstream fin("royfloyd.in");
ofstream fout("royfloyd.out");

const int Nmax=103;

int n,a[Nmax][Nmax];

int main()
{
    fin>>n;
    for ( int i=1 ; i<=n ; i++ )
        for ( int j=1 ; j<=n ; j++ )
            fin>>a[i][j];
    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];
    for ( int i=1 ; i<=n ; i++ ){
        for ( int j=1 ; j<=n ; j++ )
            fout<<a[i][j]<<' ';
        fout<<'\n';
    }
}