Uso de arboles

¿Has encontrado un error? ¿Tienes la solución? Deja tu correción ;-)

Antes de comentar: Gran parte de los ejercicios propuestos no tienen librerías debido a que Wordpress las eliminó al verlas como etiquetas HTML. Si sabes/tienes/conoces las librerías que hacen falta, déjalo en los comentarios. Y lo mas importante: Todos los ejemplos fueron realizados por estudiante con únicamente conocimiento básico del lenguaje, no de programación.

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
#include <stdio.h>
#include <stdlib.h>
 
 
typedef struct arbol{
  int clave;
  struct arbol *izq;
  struct arbol *der;
} arbol; 
void crear(arbol **a, int *preorden , int *inorden, int *pos, int izq, int der);
 
 
int main(void){
  arbol *a;
  int preorden[] = {1,2};//,4,3,5,6};
  int inorden[]  = {2,1};//,4,1,5,3,6};
  int pos = 0; 
  crear(&a, preorden, inorden, &pos, 0,1);
 
  return 0;
} 
 
void crear(arbol **a, int *preorden , int *inorden, int *pos, int izq, int der)
{
  int i; 
  if (izq > der)
    *a = NULL;
  else if (izq == der) {
    *a = (arbol *) malloc(sizeof(arbol));    (*a)->clave = preorden[*pos];
    (*a)->izq = (*a)->der = NULL;
    (*pos)++;
  }
  else {    *a = (arbol *) malloc(sizeof(arbol));
    (*a)->clave = preorden[*pos];
      /* Busca Clave 'Pos' en tabla de orden central */
    i = izq;
    while (inorden[i] != (*a)->clave) i++;      /* actualiza la posicion */
    (*pos)++;
      /* crea los subarboles izquierdo y derecho */
    crear(&(*a)->izq, preorden, inorden, pos, izq, i-1);
    crear(&(*a)->der, preorden, inorden, pos, i+1, der);  }
}

6 comentarios en "Uso de arboles"

Gervasio(Bacho)

Hola!!! en el codigo aparece & que es equivalente a &, para que lo pongas junto con los otros avisos

Punto importante: Si vas a sugerir un segmento de código en algún lenguaje debes hacerlo así:

  • Si es lenguaje C <code lang="c">Código en C</code>
  • Si es lenguaje Pascal <code lang="pascal">Aquí dentro el código de Pascal</code>.

De esta manera el código coloreas el código.

Deja un comentario

Suscribirse a los comentarios.