Cod sursa(job #2121229)

Utilizator lorena1999Marginean Lorena lorena1999 Data 3 februarie 2018 14:35:45
Problema Floyd-Warshall/Roy-Floyd Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 1.11 kb
#include <iostream>
#include <fstream>
#define MAX 101
#include <climits>

using namespace std;

ifstream f("royfloyd.in");
ofstream g("royfloyd.out");

int n, a[MAX][MAX], inf=INT_MAX;

void read()
    {
        f>>n;
        for(int i=1; i<=n; i++)
            for(int j=1; j<=n; j++)
                f>>a[i][j];
    }

void roy_warshall()
    {
        for(int i=1; i<=n; i++)
            for(int j=1; j<=n; j++)
                for(int k=1; k<=n; k++)
                    if(a[i][k]*a[k][j]!=0 && i!=j)
                        a[i][j]=1;
    }

void roy_floyd()
    {
        for(int k=1; k<=n; k++)
            for(int i=1; i<=n; i++)
                for(int j=1; j<=n; j++)1
                    if(a[i][k]*a[k][j]==0 && (a[i1][k]+a[k][j]<a[i][j] || a[i][j]==0))
                        a[i][j]=a[i][k]+a[k][j];
    }

void afis()
    {
        for(int i=1; i<=n; i++)
        {
            for(int j=1; j<=n; j++)
                g<<a[i][j]<<" ";
            g<<endl;
        }
    }

int main()
    {
        read();
        roy_floyd();
        afis();
        return 0;
    }