Ver Mensaje Individual
  #1 (permalink)  
Antiguo 15/03/2009, 18:24
alex_07
 
Fecha de Ingreso: noviembre-2007
Mensajes: 5
Antigüedad: 17 años, 2 meses
Puntos: 0
Ayuda codigo Bellman-Ford

Hola espero puedan ayudarme, tengo el siguiente codigo para el algoritmo de Bellman-Ford, el problema esque no imprime el camino al ultimo nodo, siempre aparece que no existe espero puedan ayudarme:


Código HTML:
#include<stdio.h>
#include<stdlib.h> 
    
    #define INFINITY 10000
    int graph[50][50],s[50],pathestimate[50],mark[50];
     int num_of_vertices,source,i,j,u,predecessor[50];
     int count=0;
     int minimum(int a[],int m[],int k);
     void printpath(int,int,int[]);
    void main()
     {
     
     printf("\nIntroduce el numero de vertices:\n");
     scanf("%d",&num_of_vertices);
            if(num_of_vertices<=0)
            {
              printf("\nLa matriz esta vacia\n");
              exit(1);
            }
     printf("\nIntroduce la matriz:\n");
        
        for(i=1;i<=num_of_vertices;i++)
        {
          printf("\nIntroduce los elementos del renglon %d\n",i);
           for(j=1;j<=num_of_vertices;j++)
           {
            scanf("%d",&graph[i][j]);
            }
         }
    
     printf("\nIntroduce el vertice origen\n");
     scanf("%d",&source);
    
        for(j=1;j<=num_of_vertices;j++)
        {
         mark[j]=0;
         pathestimate[j]=999;
         predecessor[j]=0;
        }
     pathestimate[source]=0;
     
     while(count<num_of_vertices)
     {
      u=minimum(pathestimate,mark,num_of_vertices);
      s[++count]=u;
      mark[u]=0;//le puse cero y tenia 1
      
      for (i = 0; i < num_of_vertices; ++i)
		s[i] = INFINITY;
       for (i = 0; i < num_of_vertices; i++){
        {
           if(pathestimate[i]>pathestimate[u]+graph[u][i])
            {
              pathestimate[i]=pathestimate[u]+graph[u][i];
              predecessor[i]=u;
        }
      }
     }
     for(i=1;i<=num_of_vertices;i++)
     {
       printpath(source,i,predecessor);
        if(pathestimate[i]!=999)
           printf("->(%d)\n",pathestimate[i]);
     }
     scanf("%d");
    }
    
}    
    int minimum(int a[],int m[],int k)
    {
     int mi=999;
     int i,t;
      for(i=1;i<=k;i++)
      {
        if(m[i]!=1)
        {
         if(mi>=a[i])
         {
          mi=a[i];
          t=i;
         }
        }
     }
     return t;
    }
    
    
    void printpath(int x,int i,int p[])
    {
     printf("\n");
     if(i==x)
      {
       printf("%d",x);
      }
       else if(p[i]==0)
       printf("no path from %d to %d",x,i);
      
       else
        {
         printpath(x,p[i],p);
         printf("..%d",i);
        }
    }