Cod sursa(job #2499064)

Utilizator 1chiriacOctavian Neculau 1chiriac Data 25 noiembrie 2019 11:06:05
Problema Floyd-Warshall/Roy-Floyd Scor 90
Compilator cpp-64 Status done
Runda Arhiva educationala Marime 0.69 kb
#include <cstdio>
#include <vector>
#include <queue>
#include <algorithm>
using namespace std;
int n,d[103][103];
int main () {
	freopen("royfloyd.in","r",stdin);
	freopen("royfloyd.out","w",stdout);
	scanf("%d", &n);
	for(int i=1;i<=n;++i)
		for(int j=1;j<=n;++j) {
			scanf("%d", &d[i][j]);
		}
	for(int k=1;k<=n;++k)
		for(int i=1;i<=n;++i)
			for(int j=1;j<=n;++j)
				if(i!=j && j!=k && i!=k) {
					if(d[i][j]==0 && d[i][k]!=0 && d[k][i]!=0)
						d[i][j]=d[i][k]+d[k][i];
					else if(d[i][j]>d[i][k]+d[k][j] && d[i][j]!=0 && d[i][k]!=0 && d[k][j]!=0)
						d[i][j]=d[i][k]+d[k][j];
				}
	for(int i=1;i<=n;++i) {
		for(int j=1;j<=n;++j)
			printf("%d ", d[i][j]);
		printf("\n");
	}
	return 0;
}