Cod sursa(job #1317853)

Utilizator DanyPrvPirvoaica Daniel DanyPrv Data 15 ianuarie 2015 11:57:34
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.75 kb
#include <fstream>
#include <limits>
using namespace std;
#define inf 1000000000
ifstream f("royfloyd.in");
ofstream g("royfloyd.out");
int a[101][101],i,j,k,n;
int main()
{
    f>>n;
    for(i=1;i<=n;i++)
        for(j=1;j<=n;j++){
            f>>a[i][j];
            if(!a[i][j]&&i!=j)
                a[i][j]=inf;
        }
    for(k=1;k<=n;k++)
        for(i=1;i<=n;i++)
            for(j=1;j<=n;j++){
                if(a[i][k]!=inf&&a[k][j]!=inf&&a[i][j]>a[i][k]+a[k][j])
                    a[i][j]=a[i][k]+a[k][j];
            }
    for(i=1;i<=n;i++){
        for(j=1;j<=n;j++)
            if(a[i][j]!=inf)
                g<<a[i][j]<<' ';
            else
                g<<0<<' ';
        g<<'\n';
    }
    return 0;
}