Pagini recente » Cod sursa (job #1203376) | Cod sursa (job #1732521) | Monitorul de evaluare | Cod sursa (job #414946) | Cod sursa (job #620943)
Cod sursa(job #620943)
#include<fstream>
using namespace std;
int main(int nrargv,char* argv[])
{
ifstream f;
ofstream g;
f.open("royfloyd.in",ios::in);
g.open("royfloyd.out",ios::out);
int n;
f>>n;
int m[100][100];
for(int i=0; i<n;i++)
for(int j=0; j<n; j++)
f>>m[i][j];
for(int k=0;k<n;k++)
for(int i=0;i<n;i++)
for(int j=0;j<n;j++)
if (m[i][k] && m[k][j] && i!=j)
{
if (m[i][j]==0) m[i][j]=m[i][k]+m[k][j];
else m[i][j]= min(m[i][j],m[i][k]+m[k][j]);
}
for(int i=0;i<n;i++)
{
for(int j=0;j<n;j++)
g<<m[i][j]<<" ";
g<<"\n";
}
f.close();
g.close();
return 0;
}