Pagini recente » Cod sursa (job #1921319) | Rating Bejenescu-Babusanu Stefan (Trifoita) | Cod sursa (job #1668346) | Cod sursa (job #522531) | Cod sursa (job #3214285)
#include <iostream>
#include <fstream>
#define MAXN 100
using namespace std;
int v[MAXN][MAXN];
int d[MAXN][MAXN];
int main(){
int n;
ifstream fin ("royfloyd.in");
fin >> n;
for(int i = 0; i < n; i ++){
for(int j = 0; j < n; j ++){
fin >> v[i][j];
}
}
fin.close();
for(int i = 0; i < n; i ++){
for(int j = 0; j < n; j ++){
for(int k = 0; k < n; k ++){
// Daca traseul de la i la j poate fi mai bun trecand prin k
if(v[i][k] && v[k][j] && i != j && (!v[i][j] || v[i][j] > v[i][k] + v[k][j]))
v[i][j] = v[i][k] + v[k][j];
}
}
}
ofstream fout ("royfloyd.out");
for(int i = 0; i < n; i ++){
for(int j = 0; j < n; j ++)
fout << v[i][j] << ' ';
fout << '\n';
}
fout.close();
return 0;
}