Cod sursa(job #2390095)

Utilizator PaterucAPetruc Andrei Stefan PaterucA Data 27 martie 2019 19:21:51
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.81 kb
#include <bits/stdc++.h>

using namespace std;

ifstream inf("royfloyd.in");
ofstream outf("royfloyd.out");

const int N=101, INF=1000000;
int n, a[N][N];

int main()
{
    inf>>n;
    for(int i=1; i<=n; i++)
    {
        for(int j=1; j<=n; j++)
        {
            inf>>a[i][j];
            if(a[i][j]==0)
                a[i][j]=INF;
        }
    }

    for(int k=1; k<=n; k++)
        for(int i=1; i<=n; i++)
            for(int j=1; j<=n; j++)
                if(i!=j&&i!=k&&j!=k)
                    a[i][j]=min(a[i][j],a[i][k]+a[k][j]);
    for(int i=1; i<=n; i++)
        {
            for(int j=1; j<=n; j++)
            {
                if(a[i][j]==INF)
                    a[i][j]=0;
                outf<<a[i][j]<<' ';
            }outf<<'\n';
        }

    return 0;
}