Cod sursa(job #1101843)

Utilizator VisuianMihaiMihai Visuian VisuianMihai Data 9 februarie 2014 12:06:52
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.75 kb
#include <fstream>
using namespace std;
ifstream fin("royfloyd.in");
ofstream fout("royfloyd.out");

int n, m, a[101][101], x, y, c;

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]&&i!=j&&(a[i][k]+a[k][j]<a[i][j]||!a[i][j]))
                    a[i][j]=a[i][k]+a[k][j];
            }
}

int main()
{
    fin>>n;
    for(int i = 1; i<= n; i++ )
        for(int j = 1; j<= n; j++ )
            fin>>a[i][j];
    RoyFloyd();
    for(int i = 1; i<= n; i++ )
    {
        for(int j = 1; j<= n; j++ )
            fout<<a[i][j]<<' ';
        fout<<'\n';
    }
    fin.close();
    fout.close();
    return 0;
}