fbpx

Problema #589 – Roy – Rezolvari PBInfo

de Mihai-Alexandru

Cerința

Se dă un graf orientat ponderat cu n noduri și m arce – în care fiecare arc are asociat un cost, număr natural strict pozitiv. Folosind algoritmul Roy-Floyd, construiți matricea costurilor minime, a[i][j] fiind costul minim al unui drum de la i la j, dacă există un asemenea drum, sau -1 în caz contrar.

Date de intrare

Fișierul de intrare roy-floyd.in conține pe prima linie numerele n m, iar următoarele linii câte un triplet i j c, cu semnificația: există arcul (i j) și are costul c.

Date de ieșire

Fișierul de ieșire roy-floyd.out va conține matricea construită, câte o linie a matricei pe o linie a fișierului, elementele de pe fiecare linie fiind separate prin exact un spațiu.

Restricții și precizări

  • 1 ≤ n ≤ 100
  • costul unui arc va fi mai mic decât 1000
  • costul unui drum este egal cu suma costurilor arcelor care îl compun

Exemplu

roy-floyd.in

5 6
1 3 1
2 1 2
4 2 1
4 3 8
5 3 5
5 4 2

roy-floyd.out

0 -1 1 -1 -1 
2 0 3 -1 -1 
-1 -1 0 -1 -1 
3 1 4 0 -1 
5 3 5 2 0 
#include <bits/stdc++.h>

using namespace std;

ifstream cin("roy-floyd.in");
ofstream cout("roy-floyd.out");

const int Inf = 0x3f3f3f3f;
int n , m , x , y , w , c[101][101];

void Floyd_Warshall()
{
    for (int k = 1; k <= n; ++k)
        for (int i = 1; i <= n; ++i)
            for (int j = 1; j <= n; ++j)
                if (i != j && c[i][j] > c[i][k] + c[k][j])
                    c[i][j] = c[i][k] + c[k][j];
}

int main()
{
    cin >> n >> m;

    for (int i = 1 ; i <= n ; ++i)
        for (int j = 1 ; j <= n ; ++j)
            if (i != j) c[i][j] = Inf;

    for(int i = 1 ; i <= m ; i++)
    {
        cin >> x >> y >> w;
        c[x][y] = w;
    }

    Floyd_Warshall();

    for (int i = 1 ; i <= n ; ++i)
    {
       for (int j = 1 ; j <= n ; ++j)
            if(c[i][j] != Inf)cout << c[i][j] << ' ';
            else cout << "-1 ";
        cout << '\n';
    }
}
Comentarii

S-ar putea sa iti placa