Cod sursa(job #3216540)

Utilizator IoanMasterUngureanu Ioan IoanMaster Data 17 martie 2024 19:06:40
Problema Floyd-Warshall/Roy-Floyd Scor 90
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.97 kb
#include <iostream>
#include <vector>
#include <fstream>

using namespace std;

#define MAXI 10000000000

ifstream fin("royfloyd.in");
ofstream fout("royfloyd.out");

int n, v[101][101];

void init()
{
    fin >> n;
    int i,j;
    for(i = 1; i <= n; i ++)
        for(j = 1; j <= n; j ++)
            {
                fin >> v[i][j];

                if(i != j && !v[i][j])
                    v[i][j] = MAXI;
            }
}

void display()
{
    int i,j;

    for (i = 1; i <= n; i++)
    {
        for (j = 1; j <= n; j++)
            fout << v[i][j] << ' ';

        fout << '\n';
    }
}

void Roy_Floyd()
{
    int k,i,j;

    for(k = 1; k <= n; k ++)
        for(i = 1; i <= n; i ++)
            for(j = 1; j <= n; j ++)
            {
                if(v[i][j] > v[i][k] + v[k][j])
                    v[i][j] = v[i][k] + v[k][j];
            }

}

int main()
{
    init();
    Roy_Floyd();
    display();

    return 0;
}