Cod sursa(job #1170485)

Utilizator Darius15Darius Pop Darius15 Data 13 aprilie 2014 18:12:55
Problema Floyd-Warshall/Roy-Floyd Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.87 kb
#include <fstream>

using namespace std;
int n,dist[105][105],best[105][105],i,j,k;
ifstream f("royfloyd.in");
ofstream g("royfloyd.out");
int main()
{
    f>>n;
    for (i=1; i<=n; i++)
        for (j=1; j<=n; j++) {
            f>>dist[i][j];
            if (dist[i][j] == 0 and i != j)
                dist[i][j] = 2000000;
        }
    for (i=1; i<=n; i++)
        for (j=1; j<=n; j++)
            best[i][j]=2000000;
    for (k=1; k<=n; k++)
        for (i=1; i<=n; i++)
            for (j=1; j<=n; j++)
                //if (dist[i][k]!=0 && dist[k][j]!=0)
                    best[i][j]=min(best[i][j],dist[i][k]+dist[k][j]);
    for (i=1; i<=n; i++)
    {
        for (j=1; j<=n; j++)
            if (best[i][j]==2000000)
                g<<0<<' ';
            else
                g<<best[i][j]<<' ';
        g<<'\n';
    }
    return 0;
}