Cod sursa(job #975471)

Utilizator petrutsxMihaela Petruta Gaman petrutsx Data 20 iulie 2013 12:53:01
Problema Floyd-Warshall/Roy-Floyd Scor 50
Compilator cpp Status done
Runda Arhiva educationala Marime 0.64 kb
#include<stdio.h>
#define NMAX 101

void RoyFloyd(short a[NMAX][NMAX], short N){
	short i, j, k;

	for(k = 1; k <= N; k++)
		for(i = 1; i <= N; i++)
			for(j = 1; j <= N; j++)
				if(a[i][j] > a[i][k] + a[k][j])
					a[i][j] = a[i][k] + a[k][j];
}

int main(){
	short i, j, N, a[NMAX][NMAX];
	FILE *pf, *pg;

	pf = fopen("royfloyd.in", "r");
	pg = fopen("royfloyd.out", "w");
	fscanf(pf, "%hd", &N);

	for(i = 1; i <= N; i++)
		for(j = 1; j <= N; j++)
			fscanf(pf, "%hd", &a[i][j]);

	RoyFloyd(a, N);

	for(i = 1; i <= N; i++){
		for(j = 1; j <= N; j++)
			fprintf(pg, "%hd ", a[i][j]);
		fprintf(pg, "\n");
	}

	fclose(pf);
	fclose(pg);

	return 0;
}