Pagini recente » Cod sursa (job #869356) | Cod sursa (job #2442578) | Cod sursa (job #1700986) | Cod sursa (job #853106) | Cod sursa (job #2222329)
#include <iostream>
#include <fstream>
#include <vector>
#include <cstdlib>
using namespace std;
int main() {
int **matrix;
int numberOfNodes;
ifstream input("royfloyd.in");
ofstream output("royfloyd.out");
input >> numberOfNodes;
matrix = (int **)calloc(numberOfNodes, sizeof(int *));
for (int i = 0; i < numberOfNodes; i++)
matrix[i] = (int *)calloc(numberOfNodes, sizeof(int));
for (int i = 0; i < numberOfNodes; i++) {
for (int j = 0; j < numberOfNodes; j++) {
input >> matrix[i][j];
}
}
for (int k = 0; k < numberOfNodes; k++) {
for (int i = 0; i < numberOfNodes; i++) {
for (int j = 0; j < numberOfNodes; j++) {
if (matrix[i][j] > matrix[i][k] + matrix[k][j])
matrix[i][j] = matrix[i][k] + matrix[k][j];
}
}
}
for (int i = 0; i < numberOfNodes; i++) {
for (int j = 0; j < numberOfNodes; j++) {
output << matrix[i][j] << " ";
}
output << endl;
}
input.close();
output.close();
return 0;
}