Pagini recente » Cod sursa (job #3029954) | Cod sursa (job #2232787) | Cod sursa (job #875786) | Cod sursa (job #2180623) | Cod sursa (job #2117286)
#include <fstream>
#include <vector>
#define Nmax 109
#define INF 2^30
using namespace std;
ifstream f("royfloyd.in");
ofstream g("royfloyd.out");
int n,m,c[Nmax][Nmax],d[Nmax][Nmax];
void RoyFloyd() {
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] && i!=j && (d[i][k]+d[k][j]<d[i][j] || d[i][j]==0))
d[i][j]=d[i][k]+d[k][j];
}
int main() {
f>>n;
for (int i=1; i<=n; ++i)
for (int j=1; j<=n; ++j) {
f>>c[i][j];
d[i][j]=c[i][j];
}
RoyFloyd();
for (int i=1; i<=n; ++i) {
for (int j=1; j<=n; ++j)
g<<d[i][j]<<' ';
g<<'\n';
}
}