Autor
|
Tema: Duda con strlen [Solucionado] (Leído 5,755 veces)
|
Dark00
Desconectado
Mensajes: 9
|
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!
|
|
« Última modificación: 11 Noviembre 2012, 19:37 pm por Dark00 »
|
En línea
|
|
|
|
0xDani
Desconectado
Mensajes: 1.077
|
int i, j=0; for(i=0; cadena[i]!='\0'; i++) { j++; if(cadena[i]==0x20) //Espacio en hexadecimal j--; }
|
|
« Última modificación: 10 Noviembre 2012, 23:10 pm por 0xDani »
|
En línea
|
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
Desconectado
Mensajes: 1.314
|
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.
|
|
« Última modificación: 10 Noviembre 2012, 21:11 pm por leosansan »
|
En línea
|
|
|
|
naderST
|
unsigned int mystrlen(char *s) { unsigned int cont = 0; for(;*s;s++) if(*s != ' ') cont++; return cont; }
|
|
|
En línea
|
|
|
|
0xDani
Desconectado
Mensajes: 1.077
|
@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
|
|
|
En línea
|
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
Desconectado
Mensajes: 1.314
|
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!.
|
|
|
En línea
|
|
|
|
Dark00
Desconectado
Mensajes: 9
|
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
|
|
« Última modificación: 11 Noviembre 2012, 20:55 pm por Dark00 »
|
En línea
|
|
|
|
rir3760
Desconectado
Mensajes: 1.639
|
Bueno, aquí voy de metiche, pedante y [CENSORED]. Con todo espero se tome como una critica constructiva. 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 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
|
|
|
En línea
|
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
|
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 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.
|
|
|
En línea
|
|
|
|
Dark00
Desconectado
Mensajes: 9
|
Excelente explicacion naderST ahora lo entiedo todo, funciona perfecto tu codigo; muchas gracias por darte el tiempo de explicarmelo
Un saludo!
|
|
« Última modificación: 11 Noviembre 2012, 19:41 pm por Dark00 »
|
En línea
|
|
|
|
|
Mensajes similares |
|
Asunto |
Iniciado por |
Respuestas |
Vistas |
Último mensaje |
|
|
[ANSI C] Split(), strlen(), mid(), Instr(), strcpy().
« 1 2 »
Programación C/C++
|
BlackZeroX
|
11
|
10,254
|
14 Enero 2011, 02:35 am
por Littlehorse
|
|
|
[FASM]strlen en ASM
ASM
|
0xDani
|
7
|
5,918
|
28 Diciembre 2012, 14:30 pm
por avesudra
|
|
|
[Micro-rutina] strlen - ANSI
« 1 2 »
ASM
|
Karcrack
|
13
|
8,040
|
4 Abril 2013, 02:14 am
por mr.blood
|
|
|
strlen() y .length()
Programación C/C++
|
erest0r
|
4
|
4,504
|
17 Septiembre 2013, 08:25 am
por erest0r
|
|
|
Duda con programa - funcion strlen?
Programación C/C++
|
welchu
|
9
|
4,729
|
18 Febrero 2014, 03:11 am
por NOB2014
|
|