Cod sursa(job #2602969)

Utilizator Andrei26Andrei Dragulin Andrei26 Data 18 aprilie 2020 12:31:04
Problema Floyd-Warshall/Roy-Floyd Scor 50
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.84 kb
#include <iostream>
#include <fstream>
using namespace std;

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

int matrice[101][101];
int N;

void citire(){
    fin>>N;
    for(int i=1;i<=N;i++){
        for(int j=1;j<=N;j++){
            fin>>matrice[i][j];
        }
    }
}

void rezolvare(){
    int i,j,k;
    for(k=1;k<=N;k++){
        for(i=1;i<=N;i++){
            for(j=1;j<=N;j++){
                if(matrice[i][j] && i!=j && matrice[i][j] > matrice[i][k] + matrice[k][j]) matrice[i][j] = matrice[i][k] + matrice[k][j];
            }
        }
    }
}

void afisare(){
    for(int i=1;i<=N;i++){
        for(int j=1;j<=N;j++){
            fout<<matrice[i][j]<<" ";
        }
        fout<<"\n";
    }
    fout.close();
}

int main(){
    citire();
    rezolvare();
    afisare();
    return 0;
}