Cod sursa(job #1741644)

Utilizator flaviu_2001Craciun Ioan-Flaviu flaviu_2001 Data 14 august 2016 17:09:21
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.8 kb
#include <fstream>

using namespace std;

int v[105][105], n;

void read(){
    ifstream fin ("royfloyd.in");
    fin >> n;
    for (int i = 0; i < n; ++i)
        for (int j = 0; j < n; ++j)
            fin >> v[i][j];
    fin.close();
}

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

void write(){
    ofstream fout ("royfloyd.out");
    for (int i = 0; i < n; ++i){
        for (int j = 0; j < n; ++j)
            fout << v[i][j] << " ";
        fout << "\n";
    }
    fout.close();
}

int main(){
    read();
    royfloyd();
    write();
    return 0;
}