Cod sursa(job #884670)

Utilizator Lokycatalin petre Loky Data 21 februarie 2013 10:19:53
Problema Floyd-Warshall/Roy-Floyd Scor 90
Compilator cpp Status done
Runda Arhiva educationala Marime 0.68 kb
#include <fstream>

using namespace std;

long int n,i,j,k,a[103][103];

int main()
{
    ifstream f("royfloyd.in");
    ofstream g("royfloyd.out");
    f>>n;
    for (i=1;i<=n;i++)
        for (j=1;j<=n;j++)
        f>>a[i][j];
    for (k=1;k<=n;k++)
        for (i=1;i<=n;i++)
            for (j=1;j<=n;j++) {
            if (a[i][j]==0&&i!=j) {a[i][j]=a[i][k]+a[k][j];}
            if (a[i][j]>a[i][k]+a[k][j] &&i!=j) {a[i][j]=a[i][k]+a[k][j];}
            }

    for (i=1;i<=n;i++) {
        for (j=1;j<=n;j++) {
        if (i==j) g<<'0'<<' ';
        else
        g<<a[i][j]<<' ';
        }
        g<<'\n';
    }

    f.close();
    g.close();
    return 0;
}