Cod sursa(job #903223)

Utilizator lianaliana tucar liana Data 1 martie 2013 19:15:22
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.86 kb
#include<stdio.h>
#define nmax 105
long i, j, k, n;
long c[nmax][nmax], cmin[nmax][nmax];

void citire()
{
    scanf("%ld",&n);
    for (i=1;i<=n;i++)
        for (j=1;j<=n;j++)
            scanf("%ld",&cmin[i][j]);
}

void rezolvare()
{
    for (k=1;k<=n;k++)
        for (i=1;i<=n;i++)
            for (j=1;j<=n;j++)
                if (i!=j)
                    if (cmin[i][k]*cmin[k][j]>0)
                        if ((cmin[i][k]+cmin[k][j]<cmin[i][j]) || (cmin[i][j]==0))
                            cmin[i][j]=cmin[i][k]+cmin[k][j];
}

void afisare()
{
    for (i=1;i<=n;i++)
    {
        for (j=1;j<=n;j++)
            printf("%ld ",cmin[i][j]);
        printf("\n");
    }
}
int main()
{
    freopen("royfloyd.in","r",stdin);
    freopen("royfloyd.out","w",stdout);
    citire();
    rezolvare();
    afisare();
    return 0;
}