Cod sursa(job #874998)

Utilizator bogdan1515rusu bogdan bogdan1515 Data 9 februarie 2013 16:10:20
Problema Floyd-Warshall/Roy-Floyd Scor 0
Compilator cpp Status done
Runda Arhiva educationala Marime 0.66 kb
#include<iostream>
#include<fstream>
using namespace std;

int n,a[105][105];
void citire()
{
	ifstream f( "Roy_floyd.in" );
	
	
	int i,j;
	f>>n;
	for( i=1;i<=n;i++)
		for(j=1;j<=n;j++)
			f>>a[i][j];
	f.close();
}
void roy_floyd()
{
	int i,j,k;
	for( k=1;k<=n;k++)
		for( i=1;i<=n;i++)
			for(j=1;j<=n;j++)
				if( a[i][k] && a[k][j] && ( (a[i][k] + a[k][j]) < a[i][j] ) || !a[i][j])  
						a[i][j]=a[i][k] + a[k][j];
}

void afis()
{
	ofstream g( "Royfloyd.out" );
	int i,j;
	for( i=1; i<=n; i++)
		{
			for( j=1; j<=n; j++)
				g<<a[i][j]<<" ";
		}
    g.close();
}
int main()
{
	citire();
	roy_floyd();
	afis();
	return 0;
}