Cod sursa(job #488814)

Utilizator claudiumihailClaudiu Mihail claudiumihail Data 30 septembrie 2010 02:26:44
Problema Floyd-Warshall/Roy-Floyd Scor 10
Compilator cpp Status done
Runda Arhiva educationala Marime 0.86 kb
#include<fstream>
#include<iostream>
using namespace std;

inline long min(const long a, const long b)
{
	if(a && b)
		return a<b?a:b;
	else
		return a?a:b;
}

int main()
{
	int n;
	fstream fin("royfloyd.in", fstream::in);
	fstream fout("royfloyd.out", fstream::out);
	
	short mat[128][128]={};
	long mins[128][128]={};
	
	fin>>n;
	
	for(int i=0; i<n; ++i)
	{
		for(int j=0; j<n; ++j)
		{
			fin>>mat[i][j];
			//cout<<mat[i][j]<<" ";
		}
		//cout<<endl;
	}
	//cout<<endl;
	
	for(int k=0; k<n; ++k)
	{
		for(int i=0; i<n; ++i)
		{
			for(int j=0; j<n; ++j)
			{
				if(i!=j)
					mins[i][j]=min(mins[i][j],mat[i][k]+mat[k][j]);
				else
					mins[i][j]=0;
			}
		}
	}
	
	for(int i=0; i<n; ++i)
	{
		for(int j=0; j<n; ++j)
		{
			fout<<mins[i][j]<<" ";
		}
		fout<<"\n";
	}
	
	fin.close();
	fout.close();
	return 0;
}