| 
	
		|  Autor | Tema: Duda con strlen [Solucionado]  (Leído 6,365 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:Saludos!.#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;}
 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: Saludos!.#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;}
 |  
						| 
								|  |  
								|  |  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. Un saludo amigosfor(;*s;s++)
  |  
						| 
								|  |  
								| « Ú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"  :'PHonestamente 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. Un saludo amigosfor(;*s;s++)
 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 | 11,167 |  14 Enero 2011, 02:35 am por Littlehorse
 |  
						|   |   | [FASM]strlen en ASM ASM
 | 0xDani | 7 | 6,413 |  28 Diciembre 2012, 14:30 pm por avesudra
 |  
						|   |   | [Micro-rutina] strlen - ANSI
							« 1 2 » ASM
 | Karcrack | 13 | 8,723 |  4 Abril 2013, 02:14 am por mr.blood
 |  
						|   |   | strlen() y .length() Programación C/C++
 | erest0r | 4 | 4,957 |  17 Septiembre 2013, 08:25 am por erest0r
 |  
						|   |   | Duda con programa - funcion strlen? Programación C/C++
 | welchu | 9 | 5,305 |  18 Febrero 2014, 03:11 am por NOB2014
 |    |