Cod sursa(job #301824)

Utilizator IeewIordache Bogdan Ieew Data 8 aprilie 2009 14:32:23
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.55 kb
#include <fstream>
using namespace std;
int a[101][101],n;

int min(int a,int b)
{return a<b?a:b;}

int main()
{int i,j,k;
ifstream in("royfloyd.in");
in>>n;
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)in>>a[i][j];
in.close();    

for(k=1;k<=n;k++)
for(i=1;i<=n;i++)
for(j=1;j<=n;j++)
if(i!=j&&i!=k&&j!=k&&a[i][k]&&a[k][j])
    if(a[i][j])a[i][j]=min(a[i][j],a[i][k]+a[k][j]);
        else a[i][j]=a[i][k]+a[k][j];
    
ofstream out("royfloyd.out");
for(i=1;i<=n;i++)
{for(j=1;j<=n;j++)out<<a[i][j]<<' ';out<<'\n';}
out.close();
return 0;
}