Cod sursa(job #1464764)

Utilizator dimavascan94VascanDumitru dimavascan94 Data 24 iulie 2015 15:56:44
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda Arhiva educationala Marime 0.63 kb
#include <iostream>
using namespace std;

int N,ponderi[101][101]={0},i,j,k;

int main()
{
	freopen("royfloyd.in","r",stdin);
	freopen("royfloyd.out","w",stdout);

	cin>>N;
	
	for (i=0;i<N;++i)
		for (j=0;j<N;++j)
			cin>>ponderi[i][j];
	
	for	(k=0;k<N;++k)
		for (i=0;i<N;++i)
			for (j=0;j<N;++j)
//				if (ponderi[i][j]>ponderi[i][k]+ponderi[k][j])
				if ((ponderi[i][j]>ponderi[i][k]+ponderi[k][j] || ponderi[i][j]==0) && ponderi[i][k]>0 && ponderi[k][j]>0 && i!=j)
					ponderi[i][j]=ponderi[i][k]+ponderi[k][j];
				
	for (i=0;i<N;++i)
	{
		for (j=0;j<N;++j)
			cout<<ponderi[i][j]<<" ";
		cout<<endl;
	}

}