Jueves 14 de Noviembre de 2024, 04:32
SoloCodigo
Bienvenido(a),
Visitante
. Por favor,
ingresa
o
regístrate
.
¿Perdiste tu
email de activación?
Inicio
Foros
Chat
Ayuda
Buscar
Ingresar
Registrarse
SoloCodigo
»
Foros
»
Programación General
»
C/C++
(Moderador:
Eternal Idol
) »
Necesito Ayuda Y Soporte
« anterior
próximo »
Imprimir
Páginas: [
1
]
Autor
Tema: Necesito Ayuda Y Soporte (Leído 2519 veces)
bobyjoe
Nuevo Miembro
Mensajes: 9
Necesito Ayuda Y Soporte
«
en:
Jueves 21 de Septiembre de 2006, 03:58 »
0
hola necesito un programa que me han dejado de tarea y no tengo la menor idea de donde empezar o por lo menos que me ayuden a hacerlo se trata de un "GENERADOR DE ARBOLES GENEALOGICOS" con interfaz grafica hasta ahorita solo hemos visto arboles pero poco en codigo sobre ellos (arboles), solo lo elemental de insertar, borrar, eliminar, etc. tengo 15 a partir de hoy para entregarlo les pido por favor que me ayuden si quieren mas especificaciones las dare lo mas pronoto posible pero si con el tema entienden por favor ayudenme y si alguien tiene una idea que me pase un programa similar
gracias!!
Tweet
bobyjoe
Nuevo Miembro
Mensajes: 9
Re: Necesito Ayuda Y Soporte
«
Respuesta #1 en:
Jueves 21 de Septiembre de 2006, 04:15 »
0
aqui les dejo mas especificado lo que quiero
Programa Generador de Árboles Genealógicos.
Objetivos. Desarrollar una aplicación con interfaz gráfica que permita generar gráficamente un árbol genealógico.
Conceptos a aplicar:
Árboles.
Operaciones Básicas sobre árboles.
Características
-El sistema permite catalogar información jerárquica es decir en una estructura de árbol.
-El sistema debe ser capaz de generar un árbol que contenga todas las descendencias de una familia.
-Por lo menos debe contener 5 niveles de descendencias.
-Debe almacenar en cada nodo: nombre de la persona, año de nacimiento, parentesco.
-Toda la información a mostrar en el árbol deberá estar almacenada previamente en un archivo de texto, el cual la aplicación se encargara de abrir y tomar cada dato para colocarlo en el árbol.
-El sistema debe permitir que el usuario realice las siguientes operaciones: agregar, eliminar y modificar información de descendientes (es decir que en todo momento se jugara con los nodos).
-El sistema debe permitir que el archivo de texto se actualice con cada cambio que el usuario decida hacer.
-El formato interno del archivo de texto lo define el estudiante.
-El sistema no debe permitir datos repetidos.
SteelX
Miembro MUY activo
Mensajes: 218
Re: Necesito Ayuda Y Soporte
«
Respuesta #2 en:
Jueves 21 de Septiembre de 2006, 06:58 »
0
Espero y no estes queriendo que te hagamos la tarea
Inside the code
Bicholey
Moderador
Mensajes: 1234
Re: Necesito Ayuda Y Soporte
«
Respuesta #3 en:
Jueves 21 de Septiembre de 2006, 09:09 »
0
pues mostrarnos algun avance y decirnos en que te estas atorando porque no hacemos tareas...
[size=109]
LOS GATOS SIEMPRE CAEMOS DE PIE !!!
[/size]
bobyjoe
Nuevo Miembro
Mensajes: 9
Re: Necesito Ayuda Y Soporte
«
Respuesta #4 en:
Viernes 22 de Septiembre de 2006, 05:11 »
0
mmmmmmm bueno yo ya avance un poco hasta el punto 3 que he especificado alla arriba y pues estoy atorado en el paso 4 noc como meter datos a un solo nodo
como puedo hacer?
bobyjoe
Nuevo Miembro
Mensajes: 9
Re: Necesito Ayuda Y Soporte
«
Respuesta #5 en:
Viernes 22 de Septiembre de 2006, 05:14 »
0
he podido lograr meter un numero por nodo
algo asi es lo de los datos o...como?
Bicholey
Moderador
Mensajes: 1234
Re: Necesito Ayuda Y Soporte
«
Respuesta #6 en:
Viernes 22 de Septiembre de 2006, 07:43 »
0
no hagas mal uso de este codigo solo tomalo de ejemplo:
Código: Text
#include <stdio.h>
#include <ctype.h>
#include <stdlib.h>
#include <string.h>
#include <conio.h>
#define true 1
void intro_nodo(void);
void lista_nodos(void);
void borra_nodo(void);
void lista_preorden();
void lista_inorden();
void lista_postorden();
struct arbol *borra();
struct arbol *crea_arbol();
struct arbol{
char clave;
struct arbol *izquierda;
struct arbol *derecha;
};
struct arbol *raiz;
struct arbol *borra (struct arbol *raiz, char nodo){
struct arbol *d1, *d2;
if(raiz->clave == nodo){
if(raiz->izquierda == raiz->derecha){
free(raiz);
return (NULL);
}
else if(raiz->izquierda == NULL){
d1 = raiz->derecha;
free(raiz);
return (d1);
}
else if(raiz->derecha == NULL){
d1 = raiz->izquierda;
free(raiz);
return (d1);
}
else{
d2 = raiz->derecha;
d1 = raiz->derecha;
while(d1->izquierda)d1 = d1->izquierda;
d1->izquierda = raiz->izquierda;
free(raiz);
return(d2);
}
}
if(raiz->clave<nodo)
raiz->derecha = (struct arbol *)borra(raiz->derecha, nodo);
else
raiz->izquierda = (struct arbol *)borra(raiz->izquierda, nodo);
return raiz;
}
struct arbol *crea_arbol(struct arbol *raiz, struct arbol *aux, char dato){
if(!aux){
aux = (struct arbol *)malloc (sizeof(struct arbol));
aux->izquierda = (struct arbol *)NULL;
aux->derecha = (struct arbol *)NULL;
aux->clave = dato;
if(!raiz)raiz = (struct arbol *) crea_arbol(raiz, raiz, dato);
else raiz->derecha = aux;
return aux;
}
if
(dato < aux->clave) (struct arbol*)crea_arbol(aux, aux->izquierda, dato);
else
if(dato > aux->clave) (struct arbol *)crea_arbol(aux, aux->derecha, dato);
}
void intro_nodo(void){
char dato;
do{
printf("\n\tIntroduzca dato: ");
gets(&dato);
if(!raiz)raiz = (struct arbol *)crea_arbol(raiz, raiz, dato);
else (struct arbol *) crea_arbol(raiz, raiz, dato);
}while(dato);
}
void borra_nodo(void){
char dato;
printf("\n\tDato a borrar: ");
gets(&dato);
(struct arbol *) borra (raiz, dato);
}
void lista_preorden(struct arbol *aux){
int orden;
if(!aux)return;
printf("\n\t%c\t", aux->clave);
lista_preorden(aux->izquierda);
lista_preorden(aux->derecha);
}
void lista_inorden(struct arbol *aux){
int orden;
if(!aux)return;
lista_inorden(aux->izquierda);
printf("\n\t%c\t", aux->clave);
lista_inorden(aux->derecha);
}
void lista_postorden(struct arbol *aux){
int orden;
if(!aux)return;
lista_postorden(aux->izquierda);
lista_postorden(aux->derecha);
printf("\n\t%c\t", aux->clave);
}
void lista_nodos(void){
clrscr();
printf("\n\tListado de los nodos del arbol");
printf("\n\tP.............Preorden");
printf("\n\tI.............Inorden");
printf("\n\tS.............Postorden");
switch(toupper(getche())){
case 'P': lista_preorden(raiz);
break;
case 'I': lista_inorden(raiz);
break;
case 'S': lista_postorden(raiz);
break;
}
}
void main(void){
raiz = (struct arbol *)NULL;
while(true){
clrscr();
printf("\n\tMenu del programa de un arbol");
printf("\n\tA.............Añadir nodo");
printf("\n\tL.............Listado de nodos");
printf("\n\tB.............Borrar nodos");
printf("\n\tX.............Terminar");
switch(toupper(getche())){
case 'A': intro_nodo();
break;
case 'L': lista_nodos();
break;
case 'B': borra_nodo();
break;
case 'X': exit(0);}}}
[size=109]
LOS GATOS SIEMPRE CAEMOS DE PIE !!!
[/size]
bobyjoe
Nuevo Miembro
Mensajes: 9
Re: Necesito Ayuda Y Soporte
«
Respuesta #7 en:
Lunes 25 de Septiembre de 2006, 03:17 »
0
solo una duda para que es este codigo de programa? este, porque con introducir y borrar, etc no tengo mucho problema
mi problema es como hago para introducir en un nodo digamos:
nombre:ddhd
edad: 25
parentesco:lkfjdlkfjdfk
como hago eso?^^
yo he podido ingresar numeros digamos el 5.
bobyjoe
Nuevo Miembro
Mensajes: 9
Re: Necesito Ayuda Y Soporte
«
Respuesta #8 en:
Lunes 25 de Septiembre de 2006, 03:23 »
0
ah y otra cosa no me corrio el programa de ese codigo que me prestaste porque me salen unos errores mira mi programa algo asi esta :
(este lo hicimos con unos compañeros pero lo de los caracteres como que casi no sabemos)
dime algo para que esto pueda capturar caracteres de la manera ya antes mencionada
#include <iostream>
using namespace std;
int valor,x,ok=0,y,result=0,numhojas=0,vector[50],r,i;
class ArbolABB {
private:
//// Clase local de Lista para Nodo de ArbolBinario:
class Nodo {
public:
// Constructor:
Nodo(const int dat, Nodo *izq=NULL, Nodo *der=NULL) :
dato(dat), izquierdo(izq), derecho(der) {}
// Miembros:
int dato;
Nodo *izquierdo;
Nodo *derecho;
};
// Punteros de la lista, para cabeza y nodo actual:
Nodo *raiz;
Nodo *actual;
int contador;
int altura;
public:
// Constructor y destructor básicos:
ArbolABB() : raiz(NULL), actual(NULL) {}
~ArbolABB() { Podar(raiz); }
// Insertar en árbol ordenado:
void Insertar(const int dat);
// Borrar un elemento del árbol:
void Borrar(const int dat);
// Función de búsqueda:
bool Buscar(const int dat);
// Comprobar si el árbol está vacío:
bool Vacio(Nodo *r) { return r==NULL; }
// Comprobar si es un nodo hoja:
bool EsHoja(Nodo *r) { return !r->derecho && !r->izquierdo; }
// Contar número de nodos:
const int NumeroNodos();
const int AlturaArbol();
// Calcular altura de un int:
int Altura(const int dat);
// Devolver referencia al int del nodo actual:
int &ValorActual() { return actual->dato; }
// Moverse al nodo raiz:
void Raiz() { actual = raiz; }
// Aplicar una función a cada elemento del árbol:
void InOrden(void (*func)(int&) , Nodo *nodo=NULL, bool r=true);
void PreOrden(void (*func)(int&) , Nodo *nodo=NULL, bool r=true);
void PostOrden(void (*func)(int&) , Nodo *nodo=NULL, bool r=true);
void contarhojas(void (*func)(int&) , Nodo *nodo=NULL, bool r=true);
private:
// Funciones auxiliares
void Podar(Nodo* &);
void auxContador(Nodo*);
void auxAltura(Nodo*, int);
};
// Poda: borrar todos los nodos a partir de uno, incluido
void ArbolABB::Podar(Nodo* &nodo)
{
// Algoritmo recursivo, recorrido en postorden
if(nodo) {
Podar(nodo->izquierdo); // Podar izquierdo
Podar(nodo->derecho); // Podar derecho
delete nodo; // Eliminar nodo
nodo = NULL;
}
}
// Insertar un int en el árbol ABB
void ArbolABB::Insertar(const int dat)
{
Nodo *padre = NULL;
actual = raiz;
// Buscar el int en el árbol, manteniendo un puntero al nodo padre
while(!Vacio(actual) && dat != actual->dato) {
padre = actual;
if(dat > actual->dato) actual = actual->derecho;
else if(dat < actual->dato) actual = actual->izquierdo;
}
// Si se ha encontrado el elemento, regresar sin insertar
if(!Vacio(actual)) return;
// Si padre es NULL, entonces el árbol estaba vacío, el nuevo nodo será
// el nodo raiz
if(Vacio(padre)) raiz = new Nodo(dat);
// Si el int es menor que el que contiene el nodo padre, lo insertamos
// en la rama izquierda
else if(dat < padre->dato) padre->izquierdo = new Nodo(dat);
// Si el int es mayor que el que contiene el nodo padre, lo insertamos
// en la rama derecha
else if(dat > padre->dato) padre->derecho = new Nodo(dat);
}
// Eliminar un elemento de un árbol ABB
void ArbolABB::Borrar(const int dat)
{
Nodo *padre = NULL;
Nodo *nodo;
int aux;
actual = raiz;
// Mientras sea posible que el valor esté en el árbol
while(!Vacio(actual)) {
if(dat == actual->dato) { // Si el valor está en el nodo actual
if(EsHoja(actual)) { // Y si además es un nodo hoja: lo borramos
if(padre) // Si tiene padre (no es el nodo raiz)
// Anulamos el puntero que le hace referencia
if(padre->derecho == actual) padre->derecho = NULL;
else if(padre->izquierdo == actual) padre->izquierdo = NULL;
delete actual; // Borrar el nodo
actual = NULL;
return;
}
else { // Si el valor está en el nodo actual, pero no es hoja
// Buscar nodo
padre = actual;
// Buscar nodo más izquierdo de rama derecha
if(actual->derecho) {
nodo = actual->derecho;
while(nodo->izquierdo) {
padre = nodo;
nodo = nodo->izquierdo;
}
}
// O buscar nodo más derecho de rama izquierda
else {
nodo = actual->izquierdo;
while(nodo->derecho) {
padre = nodo;
nodo = nodo->derecho;
}
}
// Intercambiar valores de no a borrar u nodo encontrado
// y continuar, cerrando el bucle. El nodo encontrado no tiene
// por qué ser un nodo hoja, cerrando el bucle nos aseguramos
// de que sólo se eliminan nodos hoja.
aux = actual->dato;
actual->dato = nodo->dato;
nodo->dato = aux;
actual = nodo;
}
}
else { // Todavía no hemos encontrado el valor, seguir buscándolo
padre = actual;
if(dat > actual->dato) actual = actual->derecho;
else if(dat < actual->dato) actual = actual->izquierdo;
}
}
}
// Recorrido de árbol en inorden, aplicamos la función func, que tiene
// el prototipo:
// void func(int&);
void ArbolABB::InOrden(void (*func)(int&) , Nodo *nodo, bool r)
{
if® nodo = raiz;
if(nodo->izquierdo) InOrden(func, nodo->izquierdo, false);
func(nodo->dato);
if(nodo->derecho) InOrden(func, nodo->derecho, false);
}
// Recorrido de árbol en preorden, aplicamos la función func, que tiene
// el prototipo:
// void func(int&);
void ArbolABB::PreOrden(void (*func)(int&), Nodo *nodo, bool r)
{
if® nodo = raiz;
func(nodo->dato);
if(nodo->izquierdo) PreOrden(func, nodo->izquierdo, false);
if(nodo->derecho) PreOrden(func, nodo->derecho, false);
}
// Recorrido de árbol en postorden, aplicamos la función func, que tiene
// el prototipo:
// void func(int&);
void ArbolABB::PostOrden(void (*func)(int&), Nodo *nodo, bool r)
{
if® nodo = raiz;
if(nodo->izquierdo) PostOrden(func, nodo->izquierdo, false);
if(nodo->derecho) PostOrden(func, nodo->derecho, false);
if((!nodo->izquierdo) && (!nodo->derecho)){
numhojas++;
vector[numhojas]=nodo->dato;
}
cout<<endl;
func(nodo->dato);
}
// Buscar un valor en el árbol
bool ArbolABB::Buscar(const int dat)
{
actual = raiz;
// Todavía puede aparecer, ya que quedan nodos por mirar
while(!Vacio(actual)) {
if(dat == actual->dato) return true; // int encontrado
else if(dat > actual->dato) actual = actual->derecho; // Seguir
else if(dat < actual->dato) actual = actual->izquierdo;
}
return false; // No está en árbol
}
// Calcular la altura del nodo que contiene el int dat
int ArbolABB::Altura(const int dat)
{
int altura = 0;
actual = raiz;
// Todavía puede aparecer, ya que quedan nodos por mirar
while(!Vacio(actual)) {
if(dat == actual->dato) return altura; // int encontrado
else {
altura++; // Incrementamos la altura, seguimos buscando
if(dat > actual->dato) actual = actual->derecho;
else if(dat < actual->dato) actual = actual->izquierdo;
}
}
return -1; // No está en árbol
}
// Contar el número de nodos
const int ArbolABB::NumeroNodos()
{
contador = 0;
auxContador(raiz); // FUnción auxiliar
return contador;
}
// Función auxiliar para contar nodos. Función recursiva de recorrido en
// preorden, el proceso es aumentar el contador
void ArbolABB::auxContador(Nodo *nodo)
{
contador++; // Otro nodo
// Continuar recorrido
if(nodo->izquierdo) auxContador(nodo->izquierdo);
if(nodo->derecho) auxContador(nodo->derecho);
}
// Calcular la altura del árbol, que es la altura del nodo de mayor altura.
const int ArbolABB::AlturaArbol()
{
altura = 0;
auxAltura(raiz, 0); // Función auxiliar
return altura;
}
// Función auxiliar para calcular altura. Función recursiva de recorrido en
// postorden, el proceso es actualizar la altura sólo en nodos hojas de mayor
// altura de la máxima actual
void ArbolABB::auxAltura(Nodo *nodo, int a)
{
// Recorrido postorden
if(nodo->izquierdo) auxAltura(nodo->izquierdo, a+1);
if(nodo->derecho) auxAltura(nodo->derecho, a+1);
// Proceso, si es un nodo hoja, y su altura es mayor que la actual del
// árbol, actualizamos la altura actual del árbol
if(EsHoja(nodo) && a > altura) altura = a;
}
// Función de prueba para recorridos del árbol
void Mostrar(int &d)
{
cout << d << ",";
}
void ArbolABB::contarhojas(void (*func)(int&), Nodo *nodo, bool r)
{
if® nodo = raiz;
if(nodo->izquierdo) PostOrden(func, nodo->izquierdo, false);
if(nodo->derecho) PostOrden(func, nodo->derecho, false);
if((!nodo->izquierdo) && (!nodo->derecho)){
numhojas++;
vector[numhojas]=nodo->dato;
}
func(nodo->dato);
}
int main()
{
ArbolABB ArbolInt;
int opc;
do{
cout<<"menu"<<endl;
cout<<"1. insertar"<<endl;
cout<<"2. borrar nodo"<<endl;
cout<<"3. buscar altura de un nodo"<<endl;
cout<<"4. calcular altura de arbol"<<endl;
cout<<"5. buscar dato"<<endl;
cout<<"6. recorrer arbol"<<endl;
cout<<"7. Contar hojas "<<endl;
cout<<"8. Salir"<<endl;
cout<<"elija una opcion"<<endl<<endl;
cin>>opc;
switch(opc){
case 1:
cout<<"digite el nuevo nodo a insertar: ";
cin>>x;
ArbolInt.Insertar(x);
cout<<endl<<endl;
break;
case 2:
cout<<"digite el nodo a borrar: "<<endl;
cin>>x;
ArbolInt.Borrar(x);
cout<<endl;
break;
case 3:
cout<<"digite el valor del nodo a buscar altura: "<<endl;
cin>>x;
cout << "Altura de "<<x<<" "<< ArbolInt.Altura(x) << endl;
break;
case 4:
cout << "Altura de arbol " << ArbolInt.AlturaArbol() << endl;
break;
case 5:
cout<<"digite el nodo a buscar: "<<endl;
cin>>y;
result=ArbolInt.Buscar(y);
if(result!=0){
cout<<"dato encontrado"<<endl;
}
if(result==0){
cout<<"el dato no existe en el arbol"<<endl<<endl;;
}
break;
case 6:
// Mostrar el árbol en tres ordenes distintos:
cout << "InOrden: ";
ArbolInt.InOrden(Mostrar);
cout << endl;
cout << "PreOrden: ";
ArbolInt.PreOrden(Mostrar);
cout << endl;
cout << "PostOrden: ";
ArbolInt.PostOrden(Mostrar);
cout << endl;
numhojas=0;//para que no aumente el numero total de hojas cuando haga el recorrido postorden
break;
case 7:
cout<<"el arbol: "<<endl;
ArbolInt.contarhojas(Mostrar);
cout<<"tiene "<<numhojas<<"hojas"<<endl;
for(i=1;i<=numhojas;i++){
cout<<"hoja "<<i<<": "<<vector
<<endl;
}//fin del for
numhojas=0;
break;
case 8:
cout<<"finalizando programa"<<endl;
break;
default:
cout<<"opcion invalida"<<endl<<endl;
break;
}//fin del switch
}while(opc!=8);
cin.get();
return 0;
}
bobyjoe
Nuevo Miembro
Mensajes: 9
Re: Necesito Ayuda Y Soporte
«
Respuesta #9 en:
Lunes 25 de Septiembre de 2006, 03:50 »
0
lo estoy trabajando con clases casi no entendi tu codigo tambien estoy trabajndo con DEV-C++ eso de pront y sacnf no lo puedo usar y no lo puedo leer
bobyjoe
Nuevo Miembro
Mensajes: 9
Re: Necesito Ayuda Y Soporte
«
Respuesta #10 en:
Lunes 25 de Septiembre de 2006, 04:01 »
0
lo estoy trabajando con clases casi no entendi tu codigo tambien estoy trabajndo con DEV-C++ eso de print y scanf no lo puedo usar y no lo puedo leer aqui esta mi codigo pero no tengo ideas de hacerle insertar chars
Bicholey
Moderador
Mensajes: 1234
Re: Necesito Ayuda Y Soporte
«
Respuesta #11 en:
Lunes 25 de Septiembre de 2006, 09:14 »
0
Por eso no nos gusta pasar codigo este programa lo hice hace años para turbo C...
yo utilice estructuras y no clases , mmmm bueno podeis checar este link y seguro encuentras algo:
http://c.conclase.net/edd/index.php?cap=006
http://search.freefind.com/find.html?id=65...uery=arboles&s=
Espero te sea de ayuda...
[size=109]
LOS GATOS SIEMPRE CAEMOS DE PIE !!!
[/size]
bobyjoe
Nuevo Miembro
Mensajes: 9
Re: Necesito Ayuda Y Soporte
«
Respuesta #12 en:
Viernes 29 de Septiembre de 2006, 07:32 »
0
Gracias!!!!!!!!!
Imprimir
Páginas: [
1
]
« anterior
próximo »
SoloCodigo
»
Foros
»
Programación General
»
C/C++
(Moderador:
Eternal Idol
) »
Necesito Ayuda Y Soporte