Pagini recente » Cod sursa (job #1364003) | Cod sursa (job #703512) | Cod sursa (job #2233227) | Cod sursa (job #1101404) | Cod sursa (job #1144837)
//Se da un graf orientat cu N noduri, memorat prin matricea ponderilor.
//Sa se determine pentru orice pereche de noduri x si y lungimea minima a drumului de la nodul x la nodul y si sa se afiseze matricea drumurilor minime. Prin lungimea unui drum intelegem suma costurilor arcelor care-l alcatuiesc.
#include <iostream>
#include <fstream>
using namespace std;
ifstream in("royfloyd.in");
ofstream out("royfloyd.out");
const int INF = 1000000000;
int n,a[101][101];
void citire()
{
in>>n;
for(int i=1;i<=n;i++)
for(int j=1;j<=n;j++){
in>>a[i][j];
if (a[i][j] == 0 && i != j)
a[i][j] = INF;
}
}
void rw()
{
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][j])
a[i][j]=a[i][k]+a[k][j];
}
int main()
{
citire();
rw();
for(int i=1;i<=n;i++)
{
for(int j=1;j<=n;j++)
if (a[i][j] == INF)
out << "0 ";
else
out<<a[i][j]<<" ";
out<<"\n";
}
return 0;
}