Cod sursa(job #2039905)

Utilizator Mihai99Berechet Mihai Mihai99 Data 15 octombrie 2017 01:11:47
Problema Floyd-Warshall/Roy-Floyd Scor 50
Compilator cpp Status done
Runda Arhiva educationala Marime 1.05 kb
#include <iostream>
#include <fstream>
using namespace std;

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

int main() {

    int n;
    fin>>n;
    int mat[2][n][n];
    for(int i = 0; i < n; ++i) {
        for(int j = 0; j < n; ++j) {
            fin>>mat[0][i][j];
        }
    }

    for(int k = 0; k < n; ++k) {
        int a = k % 2, b = (k + 1) % 2;
//        cout<<k<<'\n';
//        for(int i = 0; i < n; ++i) {
//            for(int j = 0; j < n; ++j) {
//                cout<<mat[a][i][j]<<' ';
//            } cout<<'\n';
//        } cout<<'\n';

        for(int i = 0; i < n; ++i) {
            for(int j = 0; j < n; ++j) {
//                cout<<i<<' '<<j<<"     "<<mat[a][i][j]<<"   "<<mat[a][i][k] + mat[a][k][j]<<'\n';
                mat[b][i][j] = min(mat[a][i][j], mat[a][i][k] + mat[a][k][j]);
            }
        } // cout<<'\n';
    }

    for(int i = 0; i < n; ++i) {
        for(int j = 0; j < n; ++j) {
            fout<<mat[n % 2][i][j]<<' ';
        } fout<<'\n';
    }

    return 0;
}