Cod sursa(job #1112356)

Utilizator acelasiStanciu Rares acelasi Data 19 februarie 2014 18:40:46
Problema Floyd-Warshall/Roy-Floyd Scor 50
Compilator cpp Status done
Runda Arhiva educationala Marime 0.93 kb
#include <iostream>
#include <fstream>
using namespace std;

#define PInfinit 1.e20


/**
 * Roy Floyd
 *
 * Implementarea algoritmului Roy-Floyd pentru aflarea drumurilor
 * de cost minim pentru un graf memorat prin matricea costurilor.
 */
void Roy_Floyd(int A[101][101], int n)
{
    for (int k = 1; k <= n; k++)
        for (int i = 1; i <= n; i++)
            for (int j = 1; j <= n; j++)
                if (k != i && k != j && A[i][j] > A[i][k] + A[k][j])
                    A[i][j] = A[i][k] + A[k][j];
}



int main()
{
    int a[101][101]; // Matricea costurilor
    int n;

    ifstream f("royfloyd.in");
    f >> n;
    for (int i = 1; i <= n; i++)
        for (int j = 1; j <= n; j++)
        f >> a[i][j];
    f.close();

    Roy_Floyd(a, n);

    ofstream g("royfloyd.out");
    for (int i = 1; i <= n; i++)
    {
        for (int j = 1; j <= n; j++)
            g << a[i][j] << " ";
        g << '\n';
    }
    g.close();
    return 0;
}