Cod sursa(job #1144825)

Utilizator cadirmDirman Catalin cadirm Data 17 martie 2014 17:31:29
Problema Floyd-Warshall/Roy-Floyd Scor 30
Compilator cpp Status done
Runda Arhiva educationala Marime 0.94 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");

int n,a[1001][1001];

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

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++)
            out<<a[i][j]<<" ";
        out<<"\n";
    }
    return 0;
}