Cod sursa(job #1586663)

Utilizator andreeauUngureanu Andreea andreeau Data 1 februarie 2016 16:01:17
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.71 kb
#include <iostream>
#include <fstream>

using namespace std;

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

int A[105][105],n;


int main()
{
    f >> n;
    for( int i = 1; i <= n; i++ )
         for( int j = 1; j <= n; j++ )
                f >> 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++ )
            g << A[i][j] << " " ;
        g << '\n';
    }

    return 0;
}