Cod sursa(job #2660645)

Utilizator Dusceac_Bogdan24Dusceac Bogdan Dusceac_Bogdan24 Data 19 octombrie 2020 22:45:46
Problema Floyd-Warshall/Roy-Floyd Scor 20
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.63 kb
#include <bits/stdc++.h>
using namespace std;
ifstream fin("royfloyd.in");
ofstream fout("royfloyd.out");

int n,mat[105][105];

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])
					if(mat[i][j]==0 && i!=j)
						mat[i][j]=mat[i][k]+mat[k][j];
					else if(mat[i][j]>mat[i][k]+mat[k][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;
}