Cod sursa(job #1008122)

Utilizator vladrochianVlad Rochian vladrochian Data 10 octombrie 2013 11:17:28
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.52 kb
#include <cstdio>
using namespace std;
FILE *f;
unsigned int n,a[100][100],i,j,k;
int main()
{
	freopen("royfloyd.in","r",stdin);
	freopen("royfloyd.out","w",stdout);
	scanf("%u",&n);
	for (i=0;i<n;i++)
		for (j=0;j<n;j++)
			scanf("%u",&a[i][j]);
	for (k=0;k<n;k++)
		for (i=0;i<n;i++)
			for (j=0;j<n;j++)
				if (a[i][k]&&a[k][j]&&(i!=j)&&(a[i][j]>a[i][k]+a[k][j]||!a[i][j]))
					a[i][j]=a[i][k]+a[k][j];
	for (i=0;i<n;i++)
	{
		for (j=0;j<n;j++)
			printf("%u ",a[i][j]);
		printf("\n");
	}
	return 0;
}