Cod sursa(job #650863)

Utilizator andreioneaAndrei Onea andreionea Data 19 decembrie 2011 00:52:59
Problema Floyd-Warshall/Roy-Floyd Scor 10
Compilator c Status done
Runda Arhiva educationala Marime 0.56 kb
#include <stdio.h>
#define MAXN 100

int main()
{	
	int mat[MAXN][MAXN];
	int n;
	int i,j,k;
	FILE *fin = fopen("royfloyd.in","r");
	FILE *fout = fopen("royfloyd.out", "w");
	fscanf(fin, "%d", &n);
	for (i = 0; i<n; ++i)
		for (j = 0; j<n; ++j)
			fscanf(fin, "%d", &mat[i][j]);
	fclose(fin);
	for (i = 0; i<n; ++i)
		for(j = 0; j<n; ++j)
			for (k = 0; k<n; ++k)
				if (mat[i][j] > mat[i][k] + mat[k][j])
					mat[i][j] = mat[i][k] + mat[k][j];
	for (i = 0; i<n; fprintf(fout,"\n"), ++i)
		for(j = 0; j<n; fprintf(fout, "%d ",mat[i][j++]));
	fclose(fout);
	return 0;
}