Pagini recente » Cod sursa (job #1607399) | Cod sursa (job #1600673) | Cod sursa (job #2535149) | Cod sursa (job #2589242) | Cod sursa (job #787494)
Cod sursa(job #787494)
#include <iostream>
#include <stdio.h>
using namespace std;
#define inf 2000000000
#define max(a,b) ((a>b) ? a : b)
long x[100][100];
int n;
int main()
{
FILE *f,*g;
f=fopen("royfloyd.in","r");
g=fopen("royfloyd.out","w");
fscanf(f,"%d",&n);
for (int i=0;i<n;i++)
for (int j=0;j<n;j++){
fscanf(f,"%ld",&x[i][j]);
if(i!=j && x[i][j]==0) x[i][j]=inf;
}
for (int k=0;k<n;k++)
for(int i=0;i<n;i++)
for(int j=0;j<n;j++){
if(x[i][j]>0){
x[i][j]=min(x[i][j],x[i][k]+x[k][j]);
}
}
for (int i=0;i<n;i++){
for (int j=0;j<n;j++){
if(i!=j && x[i][j]==inf) x[i][j]=0;
fprintf(g,"%ld ",x[i][j]);
}
fprintf(g,"\n");
}
fclose(f);
fclose(g);
return 0;
}