Pagini recente » Cod sursa (job #1839801) | Cod sursa (job #2968747) | Cod sursa (job #1842541) | Cod sursa (job #1207815) | Cod sursa (job #1616088)
#include <fstream>
#define in "royfloyd.in"
#define out "royfloyd.out"
#define dmax 105
#define inf 1000000000
using namespace std;
ifstream fin(in);
ofstream fout(out);
int n, m[dmax][dmax];
void citire();
void init();
void royfloyd();
void afisare();
int main(){
citire();
royfloyd();
afisare();
return 0;
}
void citire(){
int i, j;
fin>>n;
for(i=0; i<n; ++i)
for(j=0; j<n; ++j){
fin>>m[i][j];
if(!m[i][j] && i!=j) m[i][j]=inf;
}
}
void royfloyd(){
int x, y, z;
for(z=0; z<n; ++z)
for(x=0; x<n; ++x)
for(y=0; y<n; ++y)
if(m[x][y]>m[x][z]+m[z][y])
m[x][y]=m[x][z]+m[z][y];
}
void afisare(){
int i, j;
for(i=0; i<n; ++i){
for(j=0; j<n; ++j)
if(m[i][j]==inf) fout<<0<<' ';
else fout<<m[i][j]<<' ';
fout<<'\n';
}
fout.close();
}