Cod sursa(job #1194961)

Utilizator mariusn01Marius Nicoli mariusn01 Data 5 iunie 2014 16:07:55
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.62 kb
#include <fstream>
using namespace std;

int a[102][102], n, i, j, k;

int main() {
    ifstream fin("royfloyd.in");
    ofstream fout("royfloyd.out");

    fin>>n;
    for (i=1;i<=n;i++)
        for (j=1;j<=n;j++)
            fin>>a[i][j];

    for (k=1;k<=n;k++)
        for (i=1;i<=n;i++)
            for (j=1;j<=n;j++)
                if (i!=j && a[i][k] != 0 && a[k][j]!=0 && (a[i][j] > a[i][k] + a[k][j] || a[i][j] == 0))
                    a[i][j] = a[i][k] + a[k][j];
    for (i=1;i<=n;i++) {
        for (j=1;j<=n;j++)
            fout<<a[i][j]<<" ";
        fout<<"\n";
    }

    return 0;
}