Pagini recente » Cod sursa (job #2685080) | Cod sursa (job #1644892) | Cod sursa (job #301743) | Cod sursa (job #1726154) | Cod sursa (job #2203969)
#include <fstream>
#define NMAX 120
#define INF 1e9
using namespace std;
ifstream f("royfloyd.in");
ofstream g("royfloyd.out");
int d[NMAX][NMAX];
int n;
void read_data(int &n, int d[][NMAX]){
f >> n;
for(int i = 1; i<=n; i++){
for(int j = 1; j<=n; j++){
f >> d[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(int n, int d[][NMAX]){
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];
}
}
}
}
}
void write_matrix(int n, int d[][NMAX]){
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, d);
roy_floyd(n, d);
write_matrix(n, d);
return 0;
}