Cod sursa(job #633409)

Utilizator danieladDianu Daniela danielad Data 13 noiembrie 2011 18:58:30
Problema Floyd-Warshall/Roy-Floyd Scor 90
Compilator cpp Status done
Runda Arhiva educationala Marime 0.69 kb
#include<fstream>
#define inf 0xfffffff

using namespace std;
ifstream f("royfloyd.in",ifstream::in);
ofstream g("royfloyd.out",ifstream::out);
int n,c[100][100];
void citire(int &n){
  f>>n;
  int x;
  for(int i=1;i<=n;i++)
  for(int j=1;j<=n;j++){
    f>>x;
    if(x==0)
    c[i][j]=inf;
    else
    c[i][j]=x;
  }
}
void roy(){
  for(int k=1;k<=n;k++)
  for(int i=1;i<=n;i++)
  for(int j=1;j<=n;j++)
  if(i!=j&&c[i][k]+c[k][j]<c[i][j])
  c[i][j]=c[i][k]+c[k][j];
}
  

int main()
{citire(n);
roy();
int i,j;
for(i=1;i<=n;i++){
  for(j=1;j<=n;j++)
  if(c[i][j]!=inf)
  g<<c[i][j]<<" ";
  else
  g<<"0"<<" ";
  g<<endl;
}
f.close();
g.close();

return 0;
    
}