Uso de arboles
#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); } }
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 [c]Código en C[/c]
- Si es lenguaje Pascal [pascal]Aquí dentro el código de Pascal[/pascal].
De esta manera el código coloreas el código.
Otro punto importante para muchos que sienten que se les ignora: 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 cambiar mis condiciones en el momento que así lo requiera.
¿estas de acuerdo? entonces adelante que ya te he quitado bastante tiempo leyendo esta basura de advertencias :)