Cod sursa(job #2740560)

Utilizator Uriesu_IuliusUriesu Iulius Uriesu_Iulius Data 13 aprilie 2021 15:54:59
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.8 kb
#include <bits/stdc++.h>

using namespace std;

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

int n;
int a[101][101];

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

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(i!=j)
                    if(a[i][k] && a[k][j] && (!a[i][j] || a[i][k]+a[k][j]<a[i][j]))
                        a[i][j]=a[i][k]+a[k][j];
}

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

int main()
{
    Citire();
    Roy_Floyd();
    Afisare();
    return 0;
}