Cod sursa(job #727474)

Utilizator visanrVisan Radu visanr Data 27 martie 2012 23:45:53
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.81 kb
#include <cstdio>
#include <cstdlib>
#include <cmath>
using namespace std;


long a[101][101];
int n;

void read_input()
{
     int i,j;
     scanf("%i", &n);
     for(i=0;i<n;i++) for(j=0;j<n;j++) scanf("%ld", &a[i][j]);
}


void roy_floyd()
{
     int k,i,j;
     for(k=0;k<n;k++) for(i=0;i<n;i++) for(j=0;j<n;j++) if(a[i][k] && a[k][j] && (a[i][k]+a[k][j]<a[i][j] || !a[i][j]) && i!=j) a[i][j]=a[i][k]+a[k][j];
}


void write_output()
{
     int i,j;
     for(i=0;i<n;i++)
     {
                     for(j=0;j<n;j++) printf("%ld ", a[i][j]);
                     printf("\n");
     }
}


int main()
{
    freopen("royfloyd.in","r",stdin);
    freopen("royfloyd.out","w",stdout);
    int i;
    read_input();
    roy_floyd();
    write_output();
    scanf("%i", &i);
    return 0;
}