Pagini recente » Cod sursa (job #735610) | Cod sursa (job #322982) | Cod sursa (job #3225556) | Cod sursa (job #574861) | Cod sursa (job #2202558)
#include <fstream>
#define NMAX 101
#define INF 1e9
using namespace std;
ifstream f("royfloyd.in");
ofstream g("royfloyd.out");
int a[NMAX][NMAX];
int n;
int d[NMAX][NMAX];
void read_data(int &n){
f >> n;
for(int i = 1; i<=n; i++){
for(int j = 1; j<=n; j++){
f >> a[i][j];
d[i][j] = a[i][j];
}
}
for(int i = 1; i<=n; i++){
for(int j = 1; j<=n; j++){
if(!d[i][j] && i != j){
d[i][j] = INF;
}
}
}
}
void roy_floyd(){
for(int k = 1; k<=n; k++){
for(int i = 1; i<=n; i++){
for(int j = 1; j<=n; j++){
if(d[i][k] + d[k][j] < d[i][j]){
d[i][j] = d[i][k] + d[k][j];
}
}
}
}
for(int i = 1; i<=n; i++){
for(int j = 1; j<=n; j++){
g << d[i][j] << ' ';
}
g << '\n';
}
}
int main(){
read_data(n);
roy_floyd();
return 0;
}