Cod sursa(job #2747835)

Utilizator muiepulicimatacutactu muiepulici Data 29 aprilie 2021 18:06:08
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.66 kb
#include <fstream>

int n;
int a[101][101];

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];
			}
		}
	}
}

int main() {
	std::ifstream fin("royfloyd.in");
	std::ofstream fout("royfloyd.out");

	fin >> n;

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

	fin.close();

	rw();

	for (int i = 1; i <= n; ++i) {
		for (int j = 1; j <= n; ++j)
			fout << a[i][j] << ' ';
		fout << '\n';
	}

	fout.close();

	return 0;
}