Cod sursa(job #791430)

Utilizator feelshiftFeelshift feelshift Data 24 septembrie 2012 01:16:43
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.77 kb
// Sorin Davidoi ([email protected]) - 2012-09-24 00:57
// http://infoarena.ro/problema/royfloyd
#include <fstream>
using namespace std;

const int MAXSIZE = 100 + 1;

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

int nodes, best[MAXSIZE][MAXSIZE];

int main() {
	in >> nodes;

	for (int i = 0; i < nodes; ++i)
		for (int k = 0; k < nodes; ++k)
			in >> best[i][k];

	for (int k = 0; k < nodes; ++k)
		for (int i = 0; i < nodes; ++i)
			for (int j = 0; j < nodes; ++j)
				if((best[i][j] > best[i][k] + best[k][j] || !best[i][j]) && best[i][k] && best[k][j] && i != j)
					best[i][j] = best[i][k] + best[k][j];

	for (int i = 0; i < nodes; ++i)
	{
		for (int k = 0; k < nodes; ++k)
			out << best[i][k] << ' ';
		out << '\n';
	}

	in.close();
	out.close();

	return (0);
}