Pagini recente » Diferente pentru utilizator/levap15 intre reviziile 3 si 2 | Diferente pentru problema/rayman intre reviziile 49 si 50 | Diferente pentru problema/connect intre reviziile 17 si 16 | Cod sursa (job #2342781) | Cod sursa (job #1181951)
// http://www.infoarena.ro/problema/royfloyd
#include <fstream>
using namespace std;
#define FOR(i, n) for (int i = 0; i < n; ++i)
int main() {
ifstream in("royfloyd.in");
ofstream out("royfloyd.out");
int N;
in >> N;
int a[100][100];
FOR(i, N) {
FOR(j, N) {
in >> a[i][j];
}
}
FOR(k, N) {
FOR (i, N) {
FOR (j, N) {
if ((i != j) && (a[i][k]) && (a[k][j]) && ((a[i][j] == 0) || (a[i][k] + a[k][j] < a[i][j]))) {
a[i][j] = a[i][k] + a[k][j];
}
}
}
}
FOR(i, N) {
FOR(j, N) {
out << a[i][j] << " ";
}
out << endl;
}
return 0;
}