Cod sursa(job #1586661)

Utilizator andreeauUngureanu Andreea andreeau Data 1 februarie 2016 15:55:15
Problema Floyd-Warshall/Roy-Floyd Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.75 kb
#include <iostream>
#include <fstream>

using namespace std;

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

int A[105][105],n;

void royfloyd()
{
    int i,j,k;
    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] || !A[i][j] ) && i != j )
                    A[i][j] = A[i][k] + A[k][j];
}
int main()
{
    int n,i,j;

    f >> n;
    for( i = 1; i <= n; i++ )
         for( j = 1; j <= n; j++ )
                f >> A[i][j];


    royfloyd();

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

    return 0;
}