Buscar un nodo en nuestro árbol binario de búsqueda en C++ [125]
En este tutorial vamos a buscar un nodo en nuestro árbol binario de búsqueda en C++. Cuando insertamos los elementos en nuestro árbol fue de forma ordenada osea a la izquierda los menores y a la derecha los mayores y la búsqueda de un elemento en el árbol es de igual forma como los insertamos primero buscamos el elemento del lado izquierdo si es menor y del lado derecho si es mayor
Codigo: https://github.com/programadornovato/c-/commit/a5cec63c87d358b3926136a77c4abfb9312201e4
#include <iostream> struct Nodo{ int dato; Nodo *izq; Nodo *der; }; Nodo *arbol=NULL; Nodo *crearNodo(int dato); void insertarNodo(Nodo *&arbol,int dato); void mostrarArbol(Nodo *&arbol,int cont); bool buscarNodoArbol(Nodo *&arbol,int numBuscar); void menu(); int main(){ menu(); system("pause"); return 0; } void menu(){ int opcion,dato; regresaMenu: system("cls"); std::cout<<"\tMENU\n"; std::cout<<"1.- Insertar un nodo\n"; std::cout<<"2.- Mostrar arbol\n"; std::cout<<"3.- Buscar un nodo en el arbol\n"; std::cout<<"4.- Salir\n"; std::cout<<"Humano ingresa una opcion:"; std::cin>>opcion; switch (opcion) { case 1: std::cout<<"Ingresa el numero del nodo a insertar:"; std::cin>>dato; insertarNodo(arbol,dato); system("pause"); goto regresaMenu; break; case 2: std::cout<<"\n\tARBOL\n"; mostrarArbol(arbol,0); std::cout<<"\n"; system("pause"); goto regresaMenu; break; case 3: std::cout<<"Ingrese el numero a buscar en el arbol:"; std::cin>>dato; if(buscarNodoArbol(arbol,dato)==true){ std::cout<<"El dato "<<dato<<" si se encontro en el arbol\n"; }else{ std::cout<<"El dato "<<dato<<" no se encontro en el arbol\n"; } system("pause"); goto regresaMenu; break; default: return; break; } } Nodo *crearNodo(int dato){ Nodo *nuevoNodo=new Nodo(); nuevoNodo->dato=dato; nuevoNodo->izq=NULL; nuevoNodo->der=NULL; } void insertarNodo(Nodo *&arbol,int dato){ if(arbol==NULL){ Nodo *nuevoNodo=crearNodo(dato); arbol=nuevoNodo; }else{ int valorRaiz=arbol->dato; if(dato<valorRaiz){ insertarNodo(arbol->izq,dato); }else{ insertarNodo(arbol->der,dato); } } } void mostrarArbol(Nodo *&arbol,int cont){ if(arbol==NULL){ return; }else{ mostrarArbol(arbol->der,cont+1); for (int i = 0; i < cont; i++) { std::cout<<" "; } std::cout<<arbol->dato<<"\n"; mostrarArbol(arbol->izq,cont+1); } } bool buscarNodoArbol(Nodo *&arbol,int numBuscar){ if(arbol==NULL){ return false; }else if(arbol->dato==numBuscar){ return true; }else if(numBuscar<arbol->dato){ return buscarNodoArbol(arbol->izq,numBuscar); }else{ return buscarNodoArbol(arbol->der,numBuscar); } }
🎦 [Curso] Visual Studio Code 🆚 de 0 a 100: https://www.youtube.com/playlist?list=PLCTD_CpMeEKQbdlT8efsS-veXuvYZ1UWn
📦 Descargar zip con todos los codigos: http://raboninco.com/bXZK
🎦 [CURSO] C++ DE 0 A HEROE: https://www.youtube.com/playlist?list=PLCTD_CpMeEKTofxs7iottRxJ5YPM7BOcc
🎦 [Curso] Visual Studio Code 🆚 de 0 a 100: https://www.youtube.com/playlist?list=PLCTD_CpMeEKQbdlT8efsS-veXuvYZ1UWn
Gracias por apoyar este canal: https://www.patreon.com/programadornovato
🔗 Facebook: https://facebook.com/ProgramadorNovatoOficial
🔗 Twitter: https://twitter.com/programadornova
🔗 Linkedin: https://www.linkedin.com/in/programadornovato/
🔗 Instagram: https://www.instagram.com/programadornovato/
🔗 Pagina oficial: https://www.programadornovato.com
<<Anterior tutorial Siguiente tutorial >>
Ave que vuela, a la cazuela.