Cod sursa(job #599015)

Utilizator igsifvevc avb igsi Data 27 iunie 2011 19:22:46
Problema Floyd-Warshall/Roy-Floyd Scor 20
Compilator cpp Status done
Runda Arhiva educationala Marime 0.62 kb
#include <fstream>
using namespace std;

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

int dist[100][100];

int main()
{
	int nr, i, j, k;
	
	fin >> nr;
	
	for(i = 0; i < nr; i++)
		for(j = 0; j < nr; j++)
			fin >> dist[i][j];
	
	for(i = 0; i < nr; i++)
		for(j = 0; j < nr; j++)
			for(k = 0; k < nr; k++)
				if(dist[i][k] != 0 && dist[k][j] != 0 && i != j)
				if(dist[i][k] + dist[k][j] < dist[i][j] || dist[i][j] == 0)
						dist[i][j] = dist[i][k] + dist[k][j];
	
	for(i = 0; i < nr; i++)
	{
		for(j = 0; j < nr; j++)
			fout << dist[i][j] << ' ';
		fout << '\n';
	}
	 
	fin.close();
	fout.close();
	return 0;
}