Cod sursa(job #1469130)

Utilizator tudormaximTudor Maxim tudormaxim Data 7 august 2015 16:53:17
Problema Floyd-Warshall/Roy-Floyd Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.73 kb
#include <iostream>
#include <fstream>
using namespace std;
const int nmax = 105;
int mat[nmax][nmax], n;
int main()
{
    ifstream fin ("royfloyd.in");
    ofstream fout ("royfloyd.out");
    int i, j, k;
    fin >> n;
    for(i=1; i<=n; i++)
        for(j=1; j<=n; j++)
            fin >> mat[i][j];
    for(k=1; k<=n; k++)
        for(i=1; i<=n; i++)
            for(j=1; j<=n; j++)
                if (mat[i][k] && mat[k][j] && (mat[i][j] > mat[i][k] + mat[k][j] || !mat[i][j]) && i != j)
                    mat[i][j]=mat[i][k]+mat[k][i];
    for(i=1; i<=n; i++)
    {
        for(j=1; j<=n; j++)
            fout << mat[i][j] << " ";
        fout << "\n";
    }
    fin.close();
    fout.close();
    return 0;
}