Pagini recente » Cod sursa (job #2358441) | Cod sursa (job #2696481) | Cod sursa (job #489913) | Cod sursa (job #3141983) | Cod sursa (job #488815)
Cod sursa(job #488815)
#include<fstream>
#include<iostream>
using namespace std;
inline long min(const long a, const long b)
{
if(a && b)
return a<b?a:b;
else
return a?a:b;
}
int main()
{
int n;
fstream fin("royfloyd.in", fstream::in);
fstream fout("royfloyd.out", fstream::out);
long mat[128][128]={};
fin>>n;
for(int i=0; i<n; ++i)
{
for(int j=0; j<n; ++j)
{
fin>>mat[i][j];
//cout<<mat[i][j]<<" ";
}
//cout<<endl;
}
//cout<<endl;
for(int k=0; k<n; ++k)
{
for(int i=0; i<n; ++i)
{
for(int j=0; j<n; ++j)
{
if(i!=j)
mat[i][j]=min(mat[i][j],mat[i][k]+mat[k][j]);
}
}
}
for(int i=0; i<n; ++i)
{
for(int j=0; j<n; ++j)
{
fout<<mat[i][j]<<" ";
}
fout<<"\n";
}
fin.close();
fout.close();
return 0;
}