Cod sursa(job #1983838)

Utilizator anisca22Ana Baltaretu anisca22 Data 22 mai 2017 15:57:13
Problema Floyd-Warshall/Roy-Floyd Scor 20
Compilator cpp Status done
Runda Arhiva educationala Marime 0.71 kb
#include <iostream>
#include <fstream>
#define NMAX 105
using namespace std;
ifstream fin("royfloyd.in");
ofstream fout("royfloyd.out");
int mat[NMAX][NMAX];
int n;
int main()
{
    fin>>n;
    for(int i=1;i<=n;i++)
        for(int j=1;j<=n;j++)
            fin>>mat[i][j];
        for(int i=1;i<=n;i++)
            for(int j=1;j<=n;j++)for(int k=1;k<=n;k++)
            {
                if(mat[i][k] && mat[k][j] && (mat[i][k]+mat[k][j]<mat[i][j] || mat[i][j]==0) && i!=j)
                    mat[i][j]=mat[i][k]+mat[k][j];
            }
    for(int i=1;i<=n;i++)
        {
            for(int j=1;j<=n;j++)
                fout<<mat[i][j]<<" ";
            fout<<"\n";
        }
    return 0;
}