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:
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!
int i, j=0;
for(i=0; cadena[i]!='\0'; i++)
{
j++;
if(cadena[i]==0x20) //Espacio en hexadecimal
j--;
}
Una forma simple sería:
#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.
unsigned int mystrlen(char *s)
{
unsigned int cont = 0;
for(;*s;s++)
if(*s != ' ')
cont++;
return cont;
}
@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
Inspirado por 0xDani y sin función:
#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!.
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.
for(;*s;s++)
Un saludo amigos ;D
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
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.
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.
Excelente explicacion naderST ahora lo entiedo todo, funciona perfecto tu codigo;
muchas gracias por darte el tiempo de explicarmelo
Un saludo!