Cod sursa(job #1118073)

Utilizator danyro364Savu Ioan Daniel danyro364 Data 23 februarie 2014 23:18:32
Problema Floyd-Warshall/Roy-Floyd Scor 90
Compilator cpp Status done
Runda Arhiva educationala Marime 0.63 kb
//#include <iostream>
#include <stdio.h>
using namespace std;
int d[1001][1001];
int main()
{
    int i,j,k,n=0;
    FILE *f=fopen("royfloyd.in","r"),*g=fopen("royfloyd.out","w");
    fscanf(f,"%d",&n);
    for(i=1;i<=n;i++)
        for(j=1;j<=n;j++)
        fscanf(f,"%d",&d[i][j]);
    for(k=1;k<=n;k++)
        for(i=1;i<=n;i++)
            for(j=1;j<=n;j++)
            if(d[i][k]&&d[j][k]&&i!=j&&(!d[i][j]||d[i][j]>d[i][k]+d[k][j]))
                d[i][j]=d[i][k]+d[k][j];
    for(i=1;i<=n;i++)
    {
        for(j=1;j<=n;j++)
            fprintf(g,"%d ",d[i][j]);
        fprintf(g,"\n");
    }

    return 0;
}