Cod sursa(job #2487900)

Utilizator Bogdan_BuzatuBuzatu Bogdan Mihai Bogdan_Buzatu Data 5 noiembrie 2019 20:55:29
Problema Floyd-Warshall/Roy-Floyd Scor 50
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 1.02 kb
#include <fstream>
using namespace std;
ifstream fin("royfloyd.in");
ofstream fout("royfloyd.out");

int a[120][120],m,n,x,y,cost;

int main(){

    fin>>n;
    for(int i=1;i<=n;i++){
        for(int j=1;j<=n;j++){
           a[i][j]=1000000;
        }
    }
   for(int i=1;i<=n;i++){
        for(int j=1;j<=n;j++){
           fin>>a[i][j];
        }
    }

    for(int k=1;k<=n;k++){
        for(int i=1;i<=n;i++){
            for(int j=1;j<=n;j++){
                if(a[i][j]>a[i][k]+a[k][j]){
                    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]==1000000 &&i!=j){
                fout<<"-1"<<" ";
           }
           else{
                if(i==j){
                    fout<<"0"<<" ";
                }
                else{
                    fout<<a[i][j]<<" ";
                }
           }
        }
        fout<<"\n";
    }





    return 0;

}