Código de C/Visual C - Funciones de tratamiento de strings

Funciones de tratamiento de stringsgráfica de visualizaciones


C/Visual C

Publicado el 14 de Enero del 2003 por Sebastian
6.875 visualizaciones desde el 14 de Enero del 2003. Una media de 14 por semana
Funciones de tratamiento de strings sin utilizar la biblioteca string.h.

Versión 1

Publicado el 14 de Enero del 2003gráfica de visualizaciones de la versión: Versión 1
6.876 visualizaciones desde el 14 de Enero del 2003. Una media de 14 por semana
estrellaestrellaestrellaestrellaestrella
estrellaestrellaestrellaestrella
estrellaestrellaestrella
estrellaestrella
estrella

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
/*Id. programa: String 1                                                      */
/*Autor: Nieva, Sebastian                                                     */
/*Fecha de creacion: 18/03/02                                                 */
/*Fecha de ultima modificacion: 18/03/02                                      */
/*Tarea: Implementar las siguientes funciones de cadena, sin utilizar la
			biblioteca string.h

       int strlen(char *s)
            Devuelve un entero que es la longitud de la cadena s.

       char *strcpy(char *dest, char *orig)
            Copia el  contenido de  la cadena orig en la cadena dest y de-
            vuelve un puntero a la nueva cadena.

       char *strcat(char *dest, char *orig)
            Concatena la cadena orig a continuación de la cadena dest; de-
            vuelve un puntero a la nueva cadena.

       char *strchr(char *s, int a)
            Busca la primera aparición del cararcter a en la cadena s; re-
            torna un puntero al caracter si lo encontró o a NULL.

       int strcmp(char *a, char *b)
            Compara las cadenas  a y b; devuelve un 0 si ambas cadenas son
            iguales, un número menor a 0 si a < b y mayor a 0 si a > b.

       char *strlwr(char *s)
            Convierte una cadena a minúsculas; retorna puntero a la cadena.
																				*/
/*Version: 1.0                                                                */
/*Lenguaje: ANSI C                                                            */
/*Requerimientos: Nada                                                        */
/*Recibe: Nada                                                                */
/*Entrega: Nada                                                               */
 
#include<stdio.h>
#include<conio.h>
 
#define MAX 256
 
int ingresar(char *, char *);
int strlen(char *);
char *strcpy(char *, char *);
char *strcat(char *, char *);
char *strchr(char *, int);
int strcmp(char *, char *);
char *strlwr(char *);
 
void main(void)
{
	char cadena1[MAX], cadena2[MAX];
	int caracter;
 
	clrscr();
	printf ("\t\t\t*****************\n");
	printf ("\t\t\t*  EJERCICIO 1  *\n");
	printf ("\t\t\t*****************\n");
	printf ("\t\t      - PANTALLA PRINCIPAL -\n\n");
 
	caracter=ingresar(cadena1, cadena2);
	printf("LA CANTIDAD DE CARACTERES DE LA PRIMER CADENA ES: %d\n"
	"LA CANTIDAD DE CARACTERES DE LA SEGUNDA CADENA ES: %d\n",
	strlen(cadena1), strlen(cadena2));
	if(strchr(cadena1, caracter)!= NULL)
		printf("EL CARACTER ENCONTRADO ES: %c\n",*strchr(cadena1, caracter));
	/*Apunta al caracter encontrado. */
	if(strcmp(cadena2,cadena1)==1)
		printf("LA CADENA DESTINO ES MAYOR QUE LA CADENA ORIGEN\n");
	else if(!strcmp(cadena2,cadena1))
		printf("LAS CADENAS SON IGUALES\n");
	else
		printf("LA CADENA DESTINO ES MENOR QUE LA CADENA ORIGEN\n");
 
	printf("LA PRIMER CADENA EN MINUSCULAS ES: %s \n",strlwr(cadena1));
	printf("LA OTRA CADENA EN MINUSCULAS ES: %s \n",strlwr(cadena2));
	printf("INICIANDO COPIA DE CADENA...\n");
	printf("%s\n", strcpy(cadena2,cadena1));/*Puntero a la nueva cadena*/
	printf("INICIANDO CONCATENACION DE CADENA...\n");
	printf("%s\n", strcat(cadena2,cadena1));
 
	printf("\n\n\n\n\n\n\n\n\n\n\nVERSION 1.0\nCOPYRIGHT 2002-2010\n");
	printf("PROGRAMA DESARROLLADO POR SEBASTIAN NIEVA \n");
	printf("OPRIMA UNA TECLA PARA TERMINAR........");
 
	getch();
}
 
int ingresar(char *s1, char *s2)
{
	printf("\nINGRESE LA PRIMER CADENA\n");
	gets(s1);
	printf("\nINGRESE LA SEGUNDA CADENA\n");
	gets(s2);
	fflush(stdin);
	printf("\nINGRESE EL CARACTER A BUSCAR\n");
	return getch();
}
 
int strlen(char *s)
{
	int cant=0;
 
	while(*s!=NULL)
	{
		cant++;
		s++;
	}
	return cant;
}
 
char *strcpy(char *d, char *o)
{
	char *inicio=d;
	while(*o!='\0')
	{
		*d=*o;
		d++;
		o++;
	}
	*d='\0';
	return inicio;//va a vivir mientras viva la variable del main a la cual
				//apunta(en este caso apunta al 1er elemento de un arreglo)
}
 
char *strcat(char *d, char *o)
{
	char *inicio=d;
	d=d+strlen(d);
 
	while(*o!= '\0')
	{
		*d=*o;
		d++;
		o++;
	}
	*d='\0';// Ya que esya en una posicion mas
 
	return inicio;
}
 
char *strchr(char *s, int a)
{
	while(*s!=NULL)
	{
		if(*s==a)
			return s;
		s++;
	}
	return NULL;
}
 
int strcmp(char *a, char *b)
{
	int canta=0, cantb=0;
	char *inicioa, *iniciob;
	inicioa=a, iniciob=b;
	while(*a!=NULL && *b!=NULL)
	{
		if(*a!=*b)
		{
			while(*inicioa!=NULL && *iniciob!=NULL)
			{
				canta+=*inicioa;
				cantb+=*iniciob;
				inicioa++;
				iniciob++;
			}
			if(canta<cantb)
				return -1;
			else
				return 1;
		}
		a++;
		b++;
	}
	return 0;
}
 
char *strlwr(char *s)
{
	char *inicio=s;               //A-Z 65-90
	while(*s!='\0')               //a-z 97-122
	{
		if(*s>='A' && *s<='Z')
			*s+=(char)32;
		s++;
	}
	return inicio;
}



Comentarios sobre la versión: Versión 1 (0)


No hay comentarios
 

Comentar la versión: Versión 1

Nombre
Correo (no se visualiza en la web)
Valoración
Comentarios

http://lwp-l.com/s478