Cod sursa(job #1144837)

Utilizator cadirmDirman Catalin cadirm Data 17 martie 2014 17:39:08
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 1.14 kb
//Se da un graf orientat cu N noduri, memorat prin matricea ponderilor.
//Sa se determine pentru orice pereche de noduri x si y lungimea minima a drumului de la nodul x la nodul y si sa se afiseze matricea drumurilor minime. Prin lungimea unui drum intelegem suma costurilor arcelor care-l alcatuiesc.
#include <iostream>
#include <fstream>

using namespace std;

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

const int INF = 1000000000;

int n,a[101][101];

void citire()
{
    in>>n;
    for(int i=1;i<=n;i++)
        for(int j=1;j<=n;j++){
            in>>a[i][j];
            if (a[i][j] == 0 && i != j)
                a[i][j] = INF;
        }
}

void rw()
{
    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][k]+a[k][j]<a[i][j])
                    a[i][j]=a[i][k]+a[k][j];
}

int main()
{
    citire();
    rw();
    for(int i=1;i<=n;i++)
    {
        for(int j=1;j<=n;j++)
            if (a[i][j] == INF)
                out << "0 ";
            else
                out<<a[i][j]<<" ";
        out<<"\n";
    }
    return 0;
}