Cod sursa(job #1452979)

Utilizator CollermanAndrei Amariei Collerman Data 22 iunie 2015 15:15:59
Problema Floyd-Warshall/Roy-Floyd Scor 50
Compilator cpp Status done
Runda Arhiva educationala Marime 0.77 kb
#include<fstream>
using namespace std;
ofstream fout("royfloyd.out");
ifstream fin("royfloyd.in");
const int MMAX = 101;

int v[MMAX][MMAX], n;

void citire()
{
    fin >> n;
    for(int i=1; i<=n; i++)
        for(int j=1; j<=n; j++)
            fin >> v[i][j];
}

void rf()
{
    for(int k=1; k<=n; k++)
        for(int i=1; i<=n; i++)
            for(int j=1; j<=n; j++)
                if(v[k][j] && v[i][k] && v[i][j] > v[k][j] + v[i][k] && i != j )
                    v[i][j] = v[k][j] + v[i][k];
}

void afis()
{
    for(int i=1; i<=n; i++) {
        for(int j=1; j<=n; j++)
            fout << v[i][j] << ' ';
        fout << '\n';
    }
}

int main()
{
    citire();
    rf();
    afis();
    fin.close();
    fout.close();
    return 0;
}