Uso de arboles
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); } } |
1 comentarios en "Uso de arboles"
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 personas con únicamente conocimiento básico del lenguaje, no de programación.
Otro 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.
Otro punto importante para muchos que crees que te he ignorado: Todos los comentarios los reviso y en su debido momento los apruebo, pero ojo con el con lo siguiente:Me reservo el derecho de alterar, publicar o no los comentarios así como también cambiar mis condiciones en el momento que yo lo requiera.
¿Si estas de acuerdo? Adelante! que ya te he quitado bastante tiempo leyendo esta basura :)
Gervasio(Bacho)
0000-00-00 00:00:00
Hola!!! en el codigo aparece & que es equivalente a &, para que lo pongas junto con los otros avisos