Error en programa de punteros

Iniciado por Error 404:, 22 Mayo 2013, 13:20 PM

0 Miembros y 2 Visitantes están viendo este tema.

Error 404:

Hola a todos ( de nuevo ), siento tener que preguntar demasiadas cosas pero espero que tengan paciencia con este novato  :-[
El problema es el siguiente, tengo que hacer el siguiente ejercicio para el manual que me estoy leyendo:

Escribir un programa con una funcion que calcule la longitud de una cadena de caracteres. El nombre de la funcion sera LongitudCadena, debe devolver un "int", y como parametros de entrada debe tener un puntero a "char". (En "main" probar con distintos tipos de cadenas:arrays y punteros. )<--- Esto no lo pillo xd.

Ahora mismo llevo esto pero no me sale, agradeceria ayuda porque la verdad lo de los punteros me esta resultando bastante dificil   :-(

No estoy pidiendo que me manden el codigo del programa entero!!! (que sino no aprendo xd), sino que me digan mi error y si es posible un ejemplo de bien usado, pero en un miniejemplo no el programa.

Muchas gracias por adelantado ;)
PD: EN EL CODIGO DONDE PONE &#241; ES UNA --->Ñ<--- QUE EL C++ NO ME LEE XD
Código (cpp) [Seleccionar]


#include <iostream>
using namespace std;
bool LongitudCadena(char* cadena);
int main() {
    char cadena[100];
    char resp[4];
     char c;
     cadena=c;
    do{
         cout << endl << endl;
         cout << "Introduce la cadena de la que desees saber su tamaño:" << endl<< endl;
         cin >> cadena ;cout << endl << endl; cin.get();
         cout << "Tamaño de la cadena: "  << c <<endl<<endl;
         system("PAUSE");
         cout << "Desea reiniciar a otra cadena: "; cin >> resp;cin.get();
         
    }
      while(resp[0]==('s'|| 'S' || 'y' || 'Y'));
   
    cin.get();
    return 0;
}
bool LongitudCadena(char* n){
     for (i=0;i<100;i++)
     do (sizeof(cadena[i])); while( cin.get());
     }


Algo me tiene que fallar en el puntero, no se si es la declaracion o que exactamente pero algo me falla...  :huh:
Gracias de nuevo ;)
Si se puede imaginar, se puede programar.

amchacon

#1
Buen post, te ha faltado decir que error te da  :silbar:

De momento veo algunos fallos:

Código (cpp) [Seleccionar]
char cadena[100];
char resp[4];
char c;
cadena=c;


¿Que pretendías hacer en la última línea? Estas asignando un puntero a una variable que ni siquiera has inicializado... Los efectos son impresivibles, borrala.

cout << "Tamaño de la cadena: "  << c <<endl<<endl;
c no es la función sino la variable que has declarado antes. Ahí deberías poner LongitudCadena(cadena)

Código (cpp) [Seleccionar]

bool LongitudCadena(char* n){
   for (i=0;i<100;i++)
   do (sizeof(cadena[i])); while( cin.get());
   }


Una funcion que obtiene la longitud de la cadena pero devuelve un bool? (bueno en teoría devuelve bool pero no has puesto ningún return). ¿Y a santo de que va el cin.get()? Además la cadena las has llamado ahí n.

El ultimo byte de una cadena se simboliza con un caracter nulo '\0'. Para calcular el tamaño de una cadena tienes que ir comprobando hasta llegar al caracter nulo:

Código (cpp) [Seleccionar]

int LongitudCadena(char* n){
  int Tamanyo = 0;

  while (n[tamanyo] != '\0')
  {
   Tamanyo++;
  }

  return Tamanyo; // Devolver el tamanyo
}

     
Por favor, no me manden MP con dudas. Usen el foro, gracias.

¡Visita mi programa estrella!

Rar File Missing: Esteganografía en un Rar

Error 404:

#2
Vale he efectuado los cambios y este es el resultado:
Código (cpp) [Seleccionar]

#include <iostream>
using namespace std;
int LongitudCadena(char* cadena){
   int tamanyo = 0;
   
   while (cadena[tamanyo] != '\0')
   {
         tamanyo++;
   }
   return tamanyo;
}


int main() {
   char cadena[100];
   char resp[4];
    char c;
   Bucle:
   
        cout << endl << endl;
        cout << "Introduce la cadena de la que desees saber su tamanyo:" << endl<< endl;
        cin >> cadena ;cout << endl << endl; cin.get();
        cout << "Tamanyo de la cadena: "  << LongitudCadena(cadena) <<endl<<endl;cin.get();
        cout << "Desea hacer a otra cadena: "; cin >> resp ;cin.get();
       
   
     if(resp[0]=='s'||resp[0]== 'S' ||resp[0]== 'y' ||resp[0]== 'Y') goto Bucle; cin.get();
   
   cin.get();
   return 0;
}


Pero lo malo es que si introduzco mas de una palabra solo me dice el tamaño de la primera y no del conjunto; supongo que por esta parte :
Código (cpp) [Seleccionar]
while (cadena[tamanyo] != '\0')
Ya que en cuanto hay un conjunto vacio deja de leer, ¿cómo podria hacer que lea mas palabras sin que cuente los espacios, es decir podria por ejemplo hacer que si lee dos conjuntos vacios (en vez de uno) deje de leer? Y de ser asi, como lo conseguiria???
Muchas gracias por tu ayuda amchacon me ha servido  :D
PD: YA SE QUE NO ES RECOMENDABLE USAR GOTO, PERO AL SER UN PROGRAMA FACIL NO CREO QUE DE PROBLEMAS AL COMPILADOR XD
Si se puede imaginar, se puede programar.

amchacon

No, el caracter nulo '\0' no es lo mismo que los espacios ' '

El problema es del cin que corta cuando pilla un espacio. Si quieres coger una linea entera:

Código (cpp) [Seleccionar]
cin.getline(cadena,100);
Por favor, no me manden MP con dudas. Usen el foro, gracias.

¡Visita mi programa estrella!

Rar File Missing: Esteganografía en un Rar

leosansan

Cita de: superkorlas en 22 Mayo 2013, 14:12 PM
Vale he efectuado los cambios y este es el resultado:
Citar
................................................................................   
     if(resp[0]=='s'||resp[0]== 'S' ||resp[0]== 'y' ||resp[0]== 'Y') goto Bucle; cin.get();
   
   cin.get();
   return 0;
}
................................................................
YA SE QUE NO ES RECOMENDABLE USAR GOTO, PERO AL SER UN PROGRAMA FACIL NO CREO QUE DE PROBLEMAS AL COMPILADOR XD

¿Y por qué no lo dejas con el do while que tenías originalmente y que tan bien funcionaba?. Ahora, por ejemplo,  tienes un "cin.get();" después de bucle que nunca se va a ejecutar ¡ ¡ ¡ ¡ ¡ y eso que el programa es cortito.

Te dejo otra opción para la función Longitud, como simple práctica/ curiosidad:

Código (cpp) [Seleccionar]
int LongitudCadena(char* n){
    int i;
    for ( i=0;n[i] != '\0';i++);
    return i; // Devolver el tamanyo
}


Saluditos!. .... ..

Error 404:

#5
Vale he metido lo de cin.getline(cadena,100) pero ahora me da un numero mas raro y sin sentido ( en el tamaño), por ejemplo si pongo como cadena "hola amigo" me devuelve 6 de tamaño... :huh: me tiene perplejo no se...
Aqui va el codigo como lo tengo actualmente por si es que lo he metido mal o algo.
PD: GRACIAS POR SU PACIENCIA Y SU AYUDA  :rolleyes:

Código (cpp) [Seleccionar]
#include <iostream>
using namespace std;
int LongitudCadena(char* cadena){
    int tamanyo = 0;
   
    while (cadena[tamanyo] != '\0')
    {
          tamanyo++;
    }
    return tamanyo;
}


int main() {
    char cadena[100];
    char resp[4];
     char c;
    do{
   
         cout << endl << endl;
         cout << "Introduce la cadena de la que desees saber su tamanyo:" << endl<< endl;
         cin >> cadena ;cout << endl << endl; cin.getline(cadena,100);
         cout << "Tamanyo de la cadena: "  << LongitudCadena(cadena) <<endl<<endl;cin.get();
         cout << "Desea hacer a otra cadena: "; cin >> resp ;cin.get();
         }
   
      while(resp[0]=='s'||resp[0]== 'S' ||resp[0]== 'y' ||resp[0]== 'Y') ;
   
    cin.get();
    return 0;
}
Si se puede imaginar, se puede programar.

amchacon

No has quitado el antiguo cin  :silbar:
Por favor, no me manden MP con dudas. Usen el foro, gracias.

¡Visita mi programa estrella!

Rar File Missing: Esteganografía en un Rar

leosansan

Cita de: superkorlas en 22 Mayo 2013, 19:56 PM
Vale he metido lo de cin.getline(cadena,100) pero ahora me da un numero mas raro y sin sentido ( en el tamaño), por ejemplo si pongo como cadena "hola amigo" me devuelve 6 de tamaño... :huh: me tiene perplejo no se...


¿Y qué querías que te devolviera?. Si lo observas con atención el primer cin "pilla" todos los caracteres "hasta" que encuentra un espacio en blanco, es decir la palabra" hola". Lo demás que queda en el buffer "_amigo" son seis caracteres que cin.get "vuelve" a meter como variable cadena y ese es el resultado que devuelve la función que calcula la longitud. Así de sencilla es la explicación de ese número que te tenía perplejo.

Saluditos! ....