Cod sursa(job #2749731)

Utilizator ParutixLungeanu Razvan Parutix Data 7 mai 2021 21:43:00
Problema Floyd-Warshall/Roy-Floyd Scor 0
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.94 kb
#include <bits/stdc++.h>

using namespace std;

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

int n, a[105][105];
int inf = INT_MAX;

void Read()
{
    int i, j;
    fin >> n;
    for(i = 1; i <= n; ++i)
    {
        for(j = 1; j <= n; ++j)
        {
            fin >> a[i][j];
            if(a[i][j] == 0)
                a[i][j] = inf;
        }
    }
}

void Roy_Floyd()
{
    int i, j, k;
    for(k = 1; k <= n; ++k)
    {
        for(i = 1; i <= n; ++i)
        {
            for(j = 1; j <= n; ++j)
            {
                if(a[i][j] > a[k][j] + a[i][k])
                    a[i][j] = a[k][j] + a[i][k];
            }
        }
    }
}

void Write()
{
    int i, j;
    for(i = 1; i <= n; ++i)
    {
        for(j = 1; j <= n; ++j)
            fout << a[i][j] << " ";
        fout << "\n";
    }
}

int main()
{
    Read();
    Roy_Floyd();
    Write();

    return 0;
}