Cod sursa(job #1498378)

Utilizator DonleenoVass Arnold Donleeno Data 8 octombrie 2015 15:23:29
Problema Floyd-Warshall/Roy-Floyd Scor 50
Compilator cpp Status done
Runda Arhiva educationala Marime 0.77 kb
#include <stdio.h>
#include <stdlib.h>

int **graph;

int main(){

	freopen("royfloyd.in", "r", stdin);
	freopen("royfloyd.out","w",stdout);
	int N;
	scanf("%d", &N);

	graph = (int**)malloc(N*sizeof(int*));
	for (int i = 0; i < N; i++)
	{
		graph[i] = (int*)malloc(N*sizeof(int));
	}

	for (int i = 0; i < N; i++)
	{
		for (int j = 0; j < N; j++)
		{
			scanf("%d", &graph[i][j]);
		}
	}
	for (int k = 0; k < N; k++)
	{
		for (int i = 0; i < N; i++)
		{
			for (int j = 0; j < N; j++)
			{
				if (graph[i][j] > graph[i][k] + graph[k][j])
				{
					graph[i][j] = graph[i][k] + graph[k][j];
				}
			}
		}
	}
	for (int i = 0; i < N; i++)
	{
		for (int j = 0; j < N; j++)
		{
			printf("%d ", graph[i][j]);
		}
		printf("\n");
	}

	return 0;

}