Duda con strlen [Solucionado]

Iniciado por Dark00, 10 Noviembre 2012, 20:16 PM

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

Dark00

Hola queridos amigos, acabo de registrarme en este magnifico foro, vengo a plantearles una
pequeña duda y es la siguiente:

Tengo pensado leer por ejemplo una frase como esta:
Código (bash) [Seleccionar]
Hola Mundo

Quiero que me devuelva la catidad de letras que contiene esta frase sin el espacio en blanco
he probado con strlen pero esta incluye tembien el espacio, me preguntaba si habria algun metodo de implementar esta exceptuando el espacio, estare pendiente de sus respuestas, gracias

Un saludo amigos!

0xDani

#1

int i, j=0;

for(i=0; cadena[i]!='\0'; i++)
{
 j++;
 if(cadena[i]==0x20) //Espacio en hexadecimal
    j--;
}
I keep searching for something that I never seem to find, but maybe I won't, because I left it all behind!

I code for $$$
Hago trabajos en C/C++
Contactar por PM

leosansan

#2
Una forma simple sería:
Código (cpp) [Seleccionar]
#include <stdio.h>
#include <string.h>

int main()
{
   int i,k,l;
   char cadena [256];
   printf ("Introduce la cadena: ");
   gets (cadena);
   k=strlen (cadena);
   printf ("long: %d",k);
   puts("\n");
   for (i=0;i<k;i++)
       {
           if (cadena[i]==' ')
               k--;
       }
   printf ("long: %d",k);
   return 0;
}

Saludos!.
P.D:El problema en el código de 0xDani es que el primer caracter sea un espacio en blanco, entonces el if se queda en un bucle cerrado.

naderST

unsigned int mystrlen(char *s)
{
    unsigned int cont = 0;

    for(;*s;s++)
        if(*s != ' ')
            cont++;
    return cont;
}

0xDani

@leosansan, modificado.

@naderST, muy bueno el codigo, pero se me ocurre una mejora, o al menos no hay que utilizar el if:
unsigned int mystrlen(char *s)
{
   unsigned int cont = 0;

   for(;*s;s++)
   *s!=0x20 ? cont++: ;
   return cont;
}


Aunque seguramente el compilador va a generar el mismo codigo, asi queda mas "pro"  :'P
I keep searching for something that I never seem to find, but maybe I won't, because I left it all behind!

I code for $$$
Hago trabajos en C/C++
Contactar por PM

leosansan

Inspirado por 0xDani y sin función:
Código (cpp) [Seleccionar]
#include <stdio.h>

int main()
{
    int i,k=0;
    char cadena [256];
    printf ("Introduce la cadena: ");
    gets (cadena);
    for (i=0;cadena[i]!='\0';i++)
        cadena[i]!=' ' ? k++:0 ;
    printf ("longitud: %d",k);
    return 0;
}

Saludos!.

Dark00

#6
Muchas gracias a todos por su valiosa ayuda; muy buenos codigos todos por cierto, me llamo la atencion el de naderST prodrias explicarmelo, ya que no lo entiendo del todo especificamente en la parte de la condicion del for.
Código (cpp) [Seleccionar]
for(;*s;s++)

Un saludo amigos  ;D

rir3760

Bueno, aquí voy de metiche, pedante y [CENSORED]. Con todo espero se tome como una critica constructiva.

Cita de: 0xDani en 10 Noviembre 2012, 23:15 PMpero se me ocurre una mejora, o al menos no hay que utilizar el if:
unsigned int mystrlen(char *s)
{
    unsigned int cont = 0;

    for(;*s;s++)
    *s!=0x20 ? cont++: ;
    return cont;
}

Aunque seguramente el compilador va a generar el mismo codigo, asi queda mas "pro"  :'P
Honestamente no. Ello porque el operador "?:" requiere de tres operandos, utilizar solo dos (como en tu caso) es un error.

La recomendación en estos casos es:
A) Si se debe realizar una operación ante una condición dada se utiliza una sentencia de selección (por ejemplo "if").
B) Si se debe elegir uno de dos valores se utiliza el operador "?:"

De nuevo: es una recomendación, nada impide usar el operador "?:" a rajatabla pero en semejante escenario su uso esta a la altura de las palabras reservadas "auto" y "register".

Veamos el ejemplo de leosansan:
cadena[i] != ' ' ? k++ : 0;
Al agregar el cero solo para cumplir con la sintaxis del lenguaje terminamos con una construcción forzada ya que solo nos interesa el incremento del contador, nada mas (y esa es la clave).

Para el caso es mejor:
if (cadena[i] != ' ')
   k++;

En el sentido de ser solo lo necesario.

Un saludo
C retains the basic philosophy that programmers know what they are doing; it only requires that they state their intentions explicitly.
--
Kernighan & Ritchie, The C programming language

naderST

Cita de: Dark00 en 10 Noviembre 2012, 23:49 PM
Muchas gracias a todos por su valiosa ayuda; muy buenos codigos todos por cierto, me llamo la atencion el de naderST prodrias explicarmelo, ya que no lo entiendo del todo especificamente en la parte de la condicion del for.

Código (cpp) [Seleccionar]
for(;*s;s++)

Un saludo amigos  ;D


Lo que hace es que va recorriendo la cadena, pero con aritmética de apuntadores. Al sumarle uno al apuntador en cada ciclo va a apuntando al siguiente caracter, es decir, va recorriendo la cadena. Lo de *s es equivalente a decir *s != '\0' va haciendo el ciclo mientras el contenido de s, que sería el caracter actual, sea distinto del caracter nulo.

Dark00

#9
Excelente explicacion naderST ahora lo entiedo todo, funciona perfecto tu codigo;
muchas gracias por darte el tiempo de explicarmelo

  Un saludo!