Cod sursa(job #903565)

Utilizator RampageSergiu Caraian Rampage Data 1 martie 2013 22:23:11
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.61 kb
#include <fstream>
using namespace std;

ifstream f ("royfloyd.in");
ofstream g ("royfloyd.out");

int n, a[101][101];

void citire()
{
	f>>n;
	for (int i=1; i<=n; ++i)
		for (int j=1; j<=n; ++j)
			f>>a[i][j];
}

void rw()
{
	for (int k=1; k<=n; ++k)
		for (int i=1; i<=n; ++i)
			for (int j=1; j<=n; ++j)
				if (i!=j && a[i][k] && a[k][j] && (a[i][j]>a[i][k]+a[k][j] || a[i][j]==0))
					a[i][j]=a[i][k]+a[k][j];
}

void afisare()
{
	for (int i=1; i<=n; ++i)
	{	
		for (int j=1; j<=n; ++j)
			g<<a[i][j]<<" ";
		g<<'\n';
	}
}

int main()
{
	citire();
	rw();
	afisare();
	return 0;
}