Cod sursa(job #650867)

Utilizator andreioneaAndrei Onea andreionea Data 19 decembrie 2011 00:57:21
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator c Status done
Runda Arhiva educationala Marime 0.63 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 (k = 0; k<n; ++k)
		for (i = 0; i<n; ++i)
			for(j = 0; j<n; ++j)			
				if (i != j && 
					((mat[i][j] > mat[i][k] + mat[k][j]) || !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;
}