Cod sursa(job #885059)

Utilizator dspMihaiDespotovici Mihai dspMihai Data 21 februarie 2013 16:42:05
Problema Floyd-Warshall/Roy-Floyd Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.78 kb
#include <iostream>
#include <algorithm>
#include <fstream.h>
using namespace std;

int i,j,n,C[101][101],tata[101][101];


void roy_floyd ()
{
   int i, j, k;
   for (k=1;k<=n;k++)
      for (i=1;i<=n;i++)
         for (j=1;j<=n;j++)
            if (C[i][k]!=0 && C[k][j]!=0)
               if (C[i][j]>C[i][k]+C[k][j])
               {
                  C[i][j] = C[i][k]+C[k][j];
                  tata[i][j] = tata[k][j];
               }
}

int main ()
{
	FILE *f,*g;
	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", &C[i][j]);
			tata[i][j]=j;
		}
	roy_floyd();
	for (i=1; i<=n; i++, fprintf(g, "\n"))
		for(j=1; j<=n; j++) 
			fprintf(g, "%d ", C[i][j]);
	return 0;
}