Cod sursa(job #1434709)

Utilizator cella.florescuCella Florescu cella.florescu Data 11 mai 2015 10:30:12
Problema Floyd-Warshall/Roy-Floyd Scor 50
Compilator c Status done
Runda Arhiva educationala Marime 0.7 kb
#include <stdio.h>
#include <stdlib.h>
#define MAXN 100
int mat[MAXN][MAXN], d[MAXN][MAXN];
int main()
{
    FILE *fin, *fout;
    int n, i, j, k;
    fin=fopen("royfloyd.in", "r");
    fscanf(fin, "%d", &n);
    for(i=0; i<n; i++)
			for(j=0; j<n; j++){
				fscanf(fin, "%d", &mat[i][j]);
				if(i!=j)
					d[i][j]=mat[i][j];
			}
		fclose(fin);
		for(k=0; k<n; k++)
			for(i=0; i<n; i++)
				for(j=0; j<n; j++)
					if(mat[i][k] && mat[k][j] && d[i][j]>d[i][k]+d[k][j] && i!=j)
						d[i][j]=d[i][k]+d[k][j];
		fout=fopen("royfloyd.out", "w");
		for(i=0; i<n; i++){
			for(j=0; j<n; j++)
				fprintf(fout, "%d ", d[i][j]);
			fprintf(fout, "\n");
		}
		fclose(fout);
    return 0;
}