Foro de elhacker.net

Programación => Programación C/C++ => Mensaje iniciado por: Y2J en 19 Agosto 2011, 16:42 pm



Título: Problema al hacer una Agenda Telefonica en C++
Publicado por: Y2J en 19 Agosto 2011, 16:42 pm
Veran, tengo que hacer una agenda telefonica donde el usuario introduzca el nombre y telefono de 10 personas , luego debe mostrar el menu con 3 opciones:
1) Buscar por nombre
2) Buscar por numero
3) Salir

el problema es que al buscar por nombre o por numero y programa se cuelga pero no me dice que hubo errores, este es el codigo:

#include <iostream>
#include <cstdlib>
#include <string.h>

using namespace std;

//Prototipos
void Leer_Datos();
void Buscar_Nombre();
void Buscar_Numero();
void Salir();
void Imprimir_Nombre(int pos);
void Imprimir_Numero(int pos);
int Menu();
//void(*Opciones[3])(void);

struct Datos
{
       int Numero;
       char Nombre[20];
}Persona[10];

void Leer_Datos()
{
     for(int i=0;i<10;i++)
     {
             cout<<"Persona "<<i+1<<": "<<endl;
             cout<<"Ingrese el Nombre: ";cin>>Persona.Nombre;
             cout<<"Ingrese Numero Telefonico: ";cin>>Persona.Numero;
             cout<<endl;
     }
}

int Menu()
{
    int opcion;
    cout<<"Agenda Telefonica"<<endl;
    cout<<"1) Buscar por Nombre\n2) Buscar por Numero de Telefono\n3) Salir"<<endl;
    cout<<"Ingrese una opcion: ";
    cin>>opcion;
    return opcion;
}

void Imprimir_Nombre(int pos)
{
     if(pos<0)
     cout<<"Dato no encontrado"<<endl;
     else
     cout<<Persona[pos].Numero;
}

void Imprimir_Numero(int pos)
{
     if(pos<0)
     cout<<"Dato no encontrado"<<endl;
     else
     cout<<Persona[pos].Nombre;
}



void Buscar_Nombre()
{
     char dato[20];
     cout<<"Ingrese el Nombre: ";cin>>dato;
     bool seguir=true;
     int i=0;
     signed int pos;
     while(i<10 && seguir)
     {
                if(strcmp(Persona.Nombre,dato)==0)   //if(strcmp(Persona.Nombre,Dato_Nombre())==0)
                {
                      seguir=false;
                      pos=i;
                }
     }
     if(seguir)
     pos=-1;
     Imprimir_Nombre(pos);
}
   

void Buscar_Numero()
{
     int dato;
     cout<<"Ingrese Numero de Telefono: ";cin>>dato;
     bool seguir=true;
     int i=0;
     signed int pos;
     while(i<10 && seguir)
     {
                if(Persona.Numero==dato)
                {
                      seguir=false;
                      pos=i;
                }
     }
     if(seguir)
     pos=-1;
     Imprimir_Numero(pos);
}


/*void Salir()  ////Eliminar
{
     exit(0);
}*/

//void(*Opciones[])(void)={Buscar_Nombre, Buscar_Numero, Salir};

int main(int argc, char *argv[])
{
    int opcion;
    Leer_Datos();
    opcion=Menu();
   
    do{
    switch(opcion)
    {
                  case 1:Buscar_Nombre();
                  case 2:Buscar_Numero();
    }
     }
    while(opcion!=3);
    //(Opciones[opcion-1])();
    system("PAUSE");
    return 0;
}
                                                           
Que  estoy haciendo mal???                 


Título: Re: Problema al hacer una Agenda Telefonica en C++
Publicado por: satu en 19 Agosto 2011, 16:55 pm
Hola

El fallo lo tienes aquí:
Código
  1. void Leer_Datos()
  2. {
  3.     for(int i=0;i<10;i++)
  4.     {
  5.             cout<<"Persona "<<i+1<<": "<<endl;
  6.             cout<<"Ingrese el Nombre: ";cin>>Persona.Nombre;
  7.             cout<<"Ingrese Numero Telefonico: ";cin>>Persona.Numero;
  8.             cout<<endl;
  9.     }
  10. }
  11.  

Deberías poner:
Código
  1. void Leer_Datos()
  2. {
  3.     for(int i=0;i<10;i++)
  4.     {
  5.             cout<<"Persona "<<i+1<<": "<<endl;
  6.             cout<<"Ingrese el Nombre: ";cin>>Persona[i].Nombre;
  7.             cout<<"Ingrese Numero Telefonico: ";cin>>Persona[i].Numero;
  8.             cout<<endl;
  9.     }
  10. }
  11.  

Saludos


Título: Re: Problema al hacer una Agenda Telefonica en C++
Publicado por: Y2J en 19 Agosto 2011, 17:09 pm
Gracias por tu respuesta hice lo que me dijiste pero al ejecutar el programa cuando pongo 1, osea buscar por nombre  luego de escribir el nombre el programa se cuelga y no me dice donde esta el error , lo mismo me pasa cundo pongo para buscar por numero, que esta mal??


Título: Re: Problema al hacer una Agenda Telefonica en C++
Publicado por: rir3760 en 19 Agosto 2011, 17:19 pm
En esas dos funciones tienes el mismo error que ya te indicaron (debes indicar el indice del elemento al cual quieres acceder).

Un saludo


Título: Re: Problema al hacer una Agenda Telefonica en C++
Publicado por: satu en 19 Agosto 2011, 17:21 pm
Hola

Se me había escapado pero en las 2 funciones de buscar haces lo mismo, te falta poner el índice:
Código
  1. Persona[i].Nombre
  2. Persona[i].Numero
  3.  

Saludos


Título: Re: Problema al hacer una Agenda Telefonica en C++
Publicado por: Y2J en 19 Agosto 2011, 17:31 pm
Ya corregi todos los lugares donde me falta poner las indices pero al ejecutar se me cuelga luego de escribir el nombre o numero a buscar, no se que pasa


Título: Re: Problema al hacer una Agenda Telefonica en C++
Publicado por: rir3760 en 19 Agosto 2011, 17:39 pm
Así es muy difícil ayudarte salvo utilizando la bola de cristal o, mejor todavía, la mascara vudú y la gallina.

Publica el código fuente completo de tu programa y lo revisamos.

Un saludo


Título: Re: Problema al hacer una Agenda Telefonica en C++
Publicado por: satu en 19 Agosto 2011, 17:42 pm
Hola

Te falta avanzar el índice cuando no coinciden los resultados:
Código
  1. if()
  2.    .......
  3. else
  4.    i++;
  5.  

Saludos


Título: Re: Problema al hacer una Agenda Telefonica en C++
Publicado por: Y2J en 19 Agosto 2011, 17:59 pm
Mother of God!!!!! no puedo creer que se me haya olvidado poner el i++ ese era el problema ahora si me funciona gracias satu y a los demas por su respuesta, esque soy nuevo en c++ y estoy aprendiendo con un libro y un curso de internet. Gracias tios

Saludos 


Título: Re: Problema al hacer una Agenda Telefonica en C++
Publicado por: satu en 19 Agosto 2011, 18:13 pm
Hola

De nada hombre, para eso estamos.

Estoy revisando el código y veo que te faltan los break de cada case del switch. Además deberías meter el menú dentro del do-while si quieres que se muestre más veces.

Saludos


Título: Re: Problema al hacer una Agenda Telefonica en C++
Publicado por: Y2J en 19 Agosto 2011, 18:21 pm
Los cases lo cambie por un array de punteros a funcion y solo me falta el menu dentro del do-while, pero me funciona ok.

Saludos