Pagini recente » Cod sursa (job #39719) | Cod sursa (job #1794252) | Cod sursa (job #479841) | Cod sursa (job #1684146) | Cod sursa (job #488814)
Cod sursa(job #488814)
#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);
short mat[128][128]={};
long mins[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)
mins[i][j]=min(mins[i][j],mat[i][k]+mat[k][j]);
else
mins[i][j]=0;
}
}
}
for(int i=0; i<n; ++i)
{
for(int j=0; j<n; ++j)
{
fout<<mins[i][j]<<" ";
}
fout<<"\n";
}
fin.close();
fout.close();
return 0;
}