Cod sursa(job #1813133)

Utilizator cella.florescuCella Florescu cella.florescu Data 22 noiembrie 2016 18:46:04
Problema Floyd-Warshall/Roy-Floyd Scor 100
Compilator cpp Status done
Runda cerculdeinfo-lectia7-grafuri Marime 0.72 kb
#include <stdio.h>
#include <stdlib.h>
#define MAXN 100
int mat[MAXN][MAXN];
int main()
{
    FILE *fin, *fout;
    int n, i, j, k;
    fin=fopen("royfloyd.in", "r");
    fscanf(fin, "%d", &n);
    for(i=0; i<n; i++)
      for(j=0; j<n; j++)
        fscanf(fin, "%d", &mat[i][j]);
    fclose(fin);
    for(k=0; k<n; k++)
      for(i=0; i<n; i++)
        for(j=0; j<n; j++)
          if(i!=j && mat[i][k] && mat[k][j] && (mat[i][j]==0 || mat[i][j]>mat[i][k]+mat[k][j]))
            mat[i][j]=mat[i][k]+mat[k][j];
    fout=fopen("royfloyd.out", "w");
    for(i=0; i<n; i++){
      for(j=0; j<n; j++)
        fprintf(fout, "%d ", mat[i][j]);
      fprintf(fout, "\n");
    }
    fclose(fout);
    return 0;
}