Cod sursa(job #1167287)

Utilizator Darius15Darius Pop Darius15 Data 4 aprilie 2014 19:04:10
Problema Floyd-Warshall/Roy-Floyd Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.86 kb
#include <fstream>

using namespace std;
int n,dist[101][101],best[101][101],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] = 1<<30-1;
        }
    for (i=1; i<=n; i++)
        for (j=1; j<=n; j++)
            best[i][j]=1<<30-1;
    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]==1<<31-1)
                g<<0<<' ';
            else
                g<<best[i][j]<<' ';
        g<<'\n';
    }
    return 0;
}