Cadenas y apuntadores Programación. Variables de tipo char Las variables de tipo char ocupan un...

Preview:

Citation preview

Cadenas y apuntadores

Programación

Variables de tipo char

Las variables de tipo char ocupan un byte.

Los valores posibles son de -128 a 127.

Las constantes de tipo char pueden especificarse utilizando un carácter o una secuencia de escape encerrada entre apóstrofos.

‘a’, ‘5’, ‘\n’

Pueden mezclarse con variables enteras.

char x, y;

int a,b;

x = 45; y = ‘a’; a = 2*x; b = 3*x – y;

Lectura de caracteresscanf (stdio.h) utilizando el formato %c. requiere presionar ENTER

getch (conio.h) no requiere de ENTER.

getchar (stdio.h) requiere presionar ENTER

#include <stdio.h>

#include <conio.h>

main(){

char p1,p2,p3=65;

printf("\ningrese un caracter: ");

p1 = getchar();

putchar(p1);

printf("\n");

printf("\nel caracteer p3 es:");

putchar(p3);

printf("\n");

printf("\ningrese otro caracter: ");

scanf("%c",&p2);

printf("%c",p2);

printf("\ningrese otro caracter: ");

p2 = getch();

printf("caracter leido: %c",p2);

getch();

}

Uso de fflushSe requiere borrar el buffer para leer correctamente

#include <stdio.h>

#include <conio.h>

main(){

char p1,p2,p3=65;

printf("\ningrese un caracter: ");

p1 = getchar();

putchar(p1);

printf("\n");

fflush(stdin);

printf("\nel caracteer p3 es:");

putchar(p3);

printf("\n");

printf("\ningrese otro caracter: ");

scanf("%c",&p2);

printf("%c",p2);

printf("\ningrese otro caracter: ");

fflush(stdin);

p2 = getch();

fflush(stdin);

printf("caracter leido: %c",p2);

getch();

}

Funciones básicas de ctype.h

Función Significado

isdigit(c)

Regresa un 1 si el argumento c es un dígito, sino regresa 0.

isalpha(c)

Regresa un 1 si el argumento c es una letra, sino regresa 0.

islower(c)

Regresa un 1 si el argumento c es una letra minúscula, sino regresa 0.

isupper(c) Regresa un 1 si el argumento c es una letra mayúscula, sino regresa 0.

tolower(c)

Regresa el carácter c convertido a minúscula.

toupper(c)

Regresa el carácter c convertido a mayúscula.

ejemplo

#include <stdio.h>#include <conio.h>#include <ctype.h>

main(){ char c1,c2,c3,c4; printf("tecle un caracter: "); c1 = getch(); fflush(stdin); if(isdigit(c1)) printf("%c es un digito\n",c1); else printf("%c NO es un digito\n",c1); printf("tecle un caracter: "); c2 = getch(); fflush(stdin); if(isalpha(c2)) printf("%c es una letra\n",c2); else printf("%c NO es una letra\n",c2);

printf("tecle un caracter: "); c3 = getch(); fflush(stdin); if(isupper(c3)){ printf("%c es una letra mayuscula\n",c3); printf("La minuscula de %c es %c\n\n",c3,tolower(c3)); } if(islower(c3)){ printf("%c es una letra minuscula\n",c2); printf("La mayuscula de %c es %c\n\n",c3,toupper(c3)); } getch();}

Ejemplo de Conversión#include <stdio.h>#include <conio.h>#include <ctype.h>char aMayuscula(char c){ if(isalpha(c)) return toupper(c); switch(c){ case 'á':return 'Á'; case 'é':return 'É'; case 'í':return 'Í'; case 'ó':return 'Ó'; case 'ú':return 'Ú'; case 'ñ':return 'Ñ'; }}main(){ printf("%c\n",aMayuscula(‘á')); getch();}

Función issymbol#include <stdio.h>#include <conio.h>

char issymbol(char c){ if(c<=47||c>=58&&c<=64||c>=91&&c<=96||c>=123) return 1; return 0;}

main(){ printf("%d \n",issymbol('2')); printf("%d \n",issymbol('a')); printf("%d \n",issymbol('A')); printf("%d \n",issymbol('(')); printf("%d \n",issymbol('?')); printf("%d \n",issymbol('[')); printf("%d \n",issymbol('{')); getch();}

tareaEscriba una función que regrese 1 si el parámetro de tipo char es letra o número.

Quiz

Que valores se imprimen en la pantalla con las siguientes sentencias:

El código ASCII de ‘A’ es 65.

char a = ‘E’;

printf(“%c es una letra, su codigo ASCII es %d\n”, a, a);

printf(“%c %d”, tolower(a), isdigit(a));

Cadenas

Una cadena de caracteres es un arreglo unidimensional de caracteres que termina con el carácter \0.

El nombre de la variable de cadena se utiliza como un apuntador al inicio del arreglo de caracteres.

Las constantes de tipo cadena se encierran entre comillas dobles.

Ejemplos:

char a[10] = “hola”;

char m[25] = “”;

char *x = “San Luis Potosí”;

Declaración e inicialización#include <stdio.h>#include <conio.h>

main(){ // declara una cadena de longitud 20 como máximo. char a[20]; // declara una cadena de longitud 20 como máximo. // el contenido es la cadena “hola”, x[4] = ‘\0’. char x[10] = "hola"; // declara una cadena de 4 caracteres mas \0 char *m = "que tal"; // declara una cadena con longitud variable char s[] = {'B','i','e','n','v','e','n','i','d','o','\0'}; // declara una cadena con longitud variable char nom[] = "juan perez"; puts(x); puts(m); puts(s); puts(nom); printf("x es \"%s\", ",x); printf("m es \"%s\", ",m); printf("s es \"%s\", ",s); printf("nom es \"%s\" ",nom); getch();}

Lectura de cadenas#include <stdio.h>#include <conio.h>

main(){ //cadena de longitud variable char cad2[10]="hola"; char *cad0; char *cad1; cad0 = "Marruecos"; puts(cad0); cad0 = "San Luis Potosi"; puts(cad0); //lectura de cadena variable gets(cad1); puts(cad1); //lectura de cadena de longitud fija printf("%s\n",cad2); gets(cad2); puts(cad2); scanf("%s",cad2); puts(cad2); getch();}

Biblioteca stdlib.h

Función Significado

atoi(cad) Convierte cadena a entero

atof(cad) Convierte cadena a double

strtod(cad,&cad2) Convierte cadena a double

atol(cad) Convierte cadena a long

strtol(cad,&cad2,base) Convierte cadena a long

Ejemplo#include <stdio.h>#include <stdlib.h>#include <conio.h>

main(){ char s1[20],*s2; int i; long l; double d; printf("introduce cadena:"); gets(s1); i = atoi(s1); l = atol(s1); d = atof(s1); printf("s1 = \"%s\"\n",s1); printf("i = %d\n",i); printf("l = %d\n",l); printf("d = %lf\n",d); l = strtol(s1,&s2,0); printf("%d, s2= %s\n",l,s2); d = strtod(s1,&s2); printf("%lf, s2= %s\n",d,s2); getch();}

Quiz

¿Qué función realiza la conversión especificada?

1. atol ___ convierte carácter a mayúscula

2. atod ___ convierte cadena a entero

3. atoi ___ convierte carácter a minúscula

4. tolower ___ convierte cadena a entero largo

5. toupper ___ convierte cadena a double

Contar caracteres

#include <stdio.h>#include <stdlib.h>#include <conio.h>

int cuenta(char s[],char c){ int i=0,cuenta=0; while(s[i]){ if(s[i]==c) cuenta++; i++; } return cuenta;}

main(){ char s[50],c; printf("Cuenta el numero de veces que aparece\nun caracter en una cadena\n"); printf("introduce cadena:"); gets(s); printf("introduce el caracter a contar:"); c = getchar(); printf("el caracter '%c' aparece %d veces\n“ , c, cuenta(s,c)); getch();}

Cuenta las vocales de una cadena

int cuentaVocales(char s[]){ int i=0,cuenta=0; while(s[i]){ if(tolower(s[i])=='a'|| tolower(s[i])=='e'|| tolower(s[i])=='i'|| tolower(s[i])=='o'|| tolower(s[i])=='u' ) cuenta++; i++; } return cuenta;}

Otra solución para contar vocales

main(){ int cuentaVocales; char s[50]; printf("Escriba cadena:"); gets(s); cuentaVocales=cuenta(s,'a')+cuenta(s,'e')+ cuenta(s,'i')+cuenta(s,'o')+cuenta(s,'u'); printf("Total de vocales %d",cuentaVocales); getch();}

Convierte a mayúsculas una cadena

void aMayusculas(char s[]){ int i=0; while(s[i]){ s[i] = toupper(s[i]); i++; }}

main(){ char s[50]; printf("Cuenta el número de vocales en una cadena\n"); printf("introduce cadena:"); gets(s); aMayusculas(s); printf("la cadena en mayusculas es:\n%s",s); getch();}

Reemplazar un carácter por otrovoid reemplaza(char s[],char c1, char c2){ int i=0; while(s[i]){ if(s[i]==c1) s[i] = c2; i++; }}main(){ char s[50],c1,c2; printf("reemplaza un caracter por otro en una cadena\n"); printf("introduce cadena:"); gets(s); printf("introduce el caracter a reemplazar:"); c1 = getchar(); fflush(stdin); printf("introduce el caracter de reemplazo:"); c2 = getchar(); reemplaza(s,c1,c2); printf("la cadena reeplazada es:\n%s",s); getch();}

Suma de dígitos de un número

#include <stdio.h>#include <ctype.h>#include <conio.h>

int sumaDigitos(char s[]){ int i=0,suma=0; while(s[i]){ if(isdigit(s[i])) suma += s[i]-'0'; i++; } return suma;}

main(){ int suma; char s[50]; printf("Escriba cadena:"); gets(s); suma = sumaDigitos(s); printf("Suma de digitos = %d",suma); getch();}

Extraer fecha del CURPEl CURP está formado por una cadena de 18 caracteres, la fecha la forman los caracteres del 5 al 10.

La siguiente función extrae el día, el mes y el año de nacimiento.

#include <stdio.h>#include <ctype.h>#include <conio.h>

void fechaCURP(char s[],int *d,int *m,int *a){ *a = 1900+(s[4]-'0')*10+(s[5]-'0'); *m = (s[6]-'0')*10+(s[7]-'0'); *d = (s[8]-'0')*10+(s[9]-'0');}

Actividad

Escriba una función que cambie todos los dígitos iguales a ‘0’ por la letra ‘o’ y los unos ‘1’ por letras ‘I’ de una cadena que pase como parámetro.

void reemplaza(char s[],char c1, char c2){ int i=0; while(s[i]){ if(s[i]==c1) s[i] = c2; i++; }}

Funciones de cadenas

Función Descripción

strcpy(cad1,cad0) Copia la cadena cad0 en la cadena cad1

strncpy(cad1,cad0,n) Copia n caracteres de la cadena cad0 en la cadena cad1

strcat(cad1,cad0) Añade una copia de cad0 al final de la cadena cad1.

strncat(cad1,cad0,n) Añade n caracteres de cad0 al final de la cadena cad1

strstr(cad1,cad0) Localiza la primera ocurrencia de la cadena cad0 en la cadena cad1, regresa el apuntador a esa cadena.

strlen(cad0) Regresa la longitud de la cadena cad0

strcmp(cad0,cad1) Compara cad0 con cad1, regresa un entero mayor, igual o menor que cero según si la cadena cad0 es mayor, igual o menor que cad2.

strchr(cad,c) Localiza la primera ocurrencia del carácter c dentro de la cadena cad y regresa el apuntador a la cadena restante.

Biblioteca string.h

Ejemplo strcpy

#include <stdio.h>#include <conio.h>#include <string.h>

int main(){ char s2[8] = "abcdefg"; char s1[8];

strcpy( s1, s2 ); printf( "s2=%s\n", s2 ); printf( "s1=%s\n", s1 ); getch(); return 0;}

Ejemplo strncpy

#include <stdio.h>#include <conio.h>#include <string.h>

int main(){ char s2[8] = "abcdefg"; char s1[8];

strncpy( s1, s2, 3); printf( "s2=%s\n", s2 ); printf( "s1=%s\n", s1 ); getch(); return 0;}

Ejemplo strcat

#include <stdio.h>#include <conio.h>#include <string.h>

int main(){ char s1[11] = "Hola "; char s2[8] = "amigos";

printf( "s1=%s\t", s1 ); printf( "s2=%s\n", s2 ); strcat( s1, s2 ); printf( "s1=%s\n", s1 ); getch(); return 0;}

Ejemplo strncat

#include <stdio.h>#include <conio.h>#include <string.h>

int main(){ char s1[11] = "Hola "; char s2[8] = "amigos";

printf( "s1=%s\t", s1 ); printf( "s2=%s\n", s2 ); strncat( s1, s2, 4); printf( "s1=%s\n", s1 ); getch(); return 0;}

Ejemplo strstr

#include <stdio.h>#include <conio.h>#include <string.h>

int main(){ char s1[13] = "Hola a todos"; char s2[3] = "la";

printf( "s1=%s\n", s1 ); printf( "s2=%s\n", s2 ); printf( "strstr(s1,s2) = %s\n", strstr( s1, s2 ) ); getch(); return 0;}

Ejemplo strlen

#include <stdio.h>#include <conio.h>#include <string.h>

int main(){ char s[13] = "Hola a todos";

printf( "s=%s\n", s ); printf( "strlen(s) = %d\n", strlen( s ) ); getch(); return 0;}

Ejemplo strcmp#include <stdio.h>#include <conio.h>#include <string.h>int main(){ char s1[10] = "Abeja"; char s2[10] = "Abeja"; int i; printf( "s1=%s\t", s1 ); printf( "s2=%s\n", s2 ); i = strcmp( s1, s2 ); printf( "s1 es " ); if( i < 0 ) printf( "menor que" ); else if( i > 0 ) printf( "mayor que" ); else printf( "igual a" ); printf( " s2 (strcmp = %d)\n",i); getch(); return 0;}

Ejemplo strchr

#include <stdio.h>#include <conio.h>#include <string.h>

int main(){ char s[20] = "Hola amigos"; char c = 'a';

printf( "s=%s\t", s ); printf( "c=%c\n", c ); printf( "strchr=%s\n", strchr( s, c ) ); getch(); return 0;}

Ejemplo contar caracteres#include <stdio.h>#include <conio.h>#include <string.h>

int main(){ char cad1[50],cad2[50],*cad3; int i=0; printf("escriba cadeba: "); gets(cad1); printf("escriba cadeba a contar: "); gets(cad2); strcpy(cad3,cad1); //localiza la primera ocurrencia printf("AQUI"); cad3 = strstr(cad3,cad2); //licaliza las demás ocurrencias while(cad3!=NULL){ i++; cad3 = strstr(cad3+1,cad2); } printf("\nSe encontraron %d ocurrencias.\n",i); getch();}

ActividadCual es la salida del siguiente programa:

#include <stdio.h>#include <conio.h>#include <string.h>

int main(){ char cad1[50]="bienvenidos a Mexico"; char cad2[50]; strcpy(cad2,cad1); printf("cad2 = %s\n",cad2); strcat(cad1,strstr(cad2,"Mex")); printf("cad1 = %s\n",cad1); strncat(cad1,cad2,10); printf("cad1 = %s\n",cad1); getch();}

Quiz

Escriba una sentencia utilizando las funciones de cadena para extraer las cadenas que se solicita de la cadena suministrada.

s1 = “San Luis Potosí” extraer “Luis”

Obtenga la cadena “esta es una cadena concatenada” a partir de las cadenas y las funciones de cadena (AYUDA: puede hacer llamadas anidadas de la función strcat)

s1 = “cadena ”

s2 = “concate”

s3 = “ es una ”

s4 = “esta”

strcpy(cad1,cad0)strncpy(cad1,cad0,n)strcat(cad1,cad0)strncat(cad1,cad0,n)strstr(cad1,cad0)strlen(cad0)strcmp(cad0,cad1)strchr(cad,c)

Arreglos de cadenas

Un arreglo de cadenas es una arreglo bidimensional de caracteres.

Podemos ver el arreglo bidimensional como un arreglo de una dimensión de cadenas de caracteres.

Se pueden utilizar las funciones revisadas anteriormente en cada elemento del arreglo.

Ordenación de una lista de nombres

#include <stdio.h>#include <string.h>#include <conio.h>

void intercambia(char cad1[50],char cad2[50]){ char temp[50]; strcpy(temp,cad1); strcpy(cad1,cad2); strcpy(cad2,temp);}

void ordena(char lista[][50],int num){ int i,j; for(i = 0;i<num-1;i++){ for(j = i+1;j<num;j++) if(strcmp(lista[i],lista[j])>0) intercambia(lista[i],lista[j]); }}

int leerLista(char lista[][50]){ int i=0,hecho=0; char s[50]; printf("Escriba los nombres (FIN=terminar)\n"); do{ gets(lista[i]); if(strcmp(lista[i],"FIN")!=0) i++; else hecho = 1; }while(!hecho); return i;}

void imprime(char lista[][50],int num){ int i; for(i = 0;i<num;i++) puts(lista[i]);}

main(){ char nombres[50][50]; int total; total = leerLista(nombres); ordena(nombres,total); imprime(nombres,total); getch();}

Apuntadores

Una variable de tipo apuntador contiene una dirección de memoria.

La dirección de memoria señalada por el apuntador es la que contiene el dato que puede ser de cualquier tipo, incluso void.

int entero, *pentero;

entero = 548;

pentero = &entero;

*pentero = -234;

548

entero

pentero

548

entero

Asigna la dirección de entero a pentero

pentero

-234

enteroNOTA: a los apuntadores solo puede asignárseles: 0, NULL o una dirección

Ejemplo#include <stdio.h>#include <conio.h>

main(){ int entero,*pentero; entero = 548; pentero = &entero; printf("La dirección de entero es %d\n",&entero); printf("el valor de pentero es %d\n",pentero); printf("el valor de entero es %d\n",entero); printf("el valor de *pentero es %d\n",*pentero); *pentero = -234; printf("el valor de entero es %d\n",entero); printf("el valor de *pentero es %d\n",*pentero); getch();}

Aritmética de apuntadoresLos apuntadores pueden utilizarse para acceder a los elementos de un arreglo.

#include <stdio.h>#include <conio.h>

main(){ int a[10]={3,4,1,8,2,3,4,5,7,0},*b; b = a;//b apunta al inicio del arreglo a printf("dirección de b es %d, el contenido es %d\n",b,*b); b = b + 1;//b apunta a a[1] printf("dirección de b es %d, el contenido es %d\n",b,*b); b = b + 3;//b apunta a a[4] printf("dirección de b es %d, el contenido es %d\n",b,*b); b = b - 2;//b apunta a a[2] printf("dirección de b es %d, el contenido es %d\n",b,*b); getch();}

#include <stdio.h>#include <conio.h>

main(){ double a[10]={3,4,1,8,2,3,4,5,7,0},*b; b = a;//b apunta al inicio del arreglo a printf("dirección de b es %d, el contenido es %lf\n",b,*b); b = b + 1;//b apunta a a[1] printf("dirección de b es %d, el contenido es %lf\n",b,*b); b = b + 3;//b apunta a a[4] printf("dirección de b es %d, el contenido es %lf\n",b,*b); b = b - 2;//b apunta a a[2] printf("dirección de b es %d, el contenido es %lf\n",b,*b); getch();}

Apuntadores y subíndices

#include <stdio.h>#include <conio.h>

main(){ double a[10]={3,4,1,8,2,3,4,5,7,0},*b; int i; b = a;//b apunta al inicio del arreglo a for(i=0;i<10;i++) printf("a[%d]=%lf\n",i,a[i]); for(i=0;i<10;i++) printf("*(b+%d)=%lf\n",i,*(b+i)); getch();}

La aritmética de apuntadores y los subíndices son equivalentes.

Apuntadores a funciones

Las funciones se comportan como apuntadores.

El nombre de la función es un apuntador al inicio del código de la función.

Las funciones pueden pasarse como parámetros a otras funciones.

Ejemplo de apuntador a función#include <stdio.h>#include <conio.h>#include <math.h>

void tabula(double a, double b,double (*fun)(double )){ double x,y; for(x=a;x<=b;x+=(b-a)/10.0){ y = (*fun)(x); printf("f(%lf) = %lf \n",x*180/3.1416,y); }}

main(){ tabula(0,3.1416/2,sin); tabula(0,3.1416/2,cos); getch();}

Salida de apuntador a funciónf(0.000000) = 0.000000f(9.000000) = 0.156435f(18.000000) = 0.309018f(27.000000) = 0.453991f(36.000000) = 0.587786f(45.000000) = 0.707108f(54.000000) = 0.809018f(63.000000) = 0.891008f(72.000000) = 0.951057f(81.000000) = 0.987689f(0.000000) = 1.000000f(9.000000) = 0.987688f(18.000000) = 0.951056f(27.000000) = 0.891006f(36.000000) = 0.809016f(45.000000) = 0.707105f(54.000000) = 0.587783f(63.000000) = 0.453988f(72.000000) = 0.309014f(81.000000) = 0.156431

¿Que valores tienen las variables?

int x. *px:

float y, *py;

x = 5;

px = &x;

*px = 2*x + *px;

y = x;

py = y;

y = *py + x;

printf(“*p = %d x = %d\n”,*px,x);

printf(“*p = %f x = %f\n”,*py,y);

x *px y *py

Suponga la siguiente declaración:

float n1 = 7.3, n2;

Escriba una sentencia para cada una de las siguientes acciones:

Declare ptrF como un apuntador a un objeto tipo float

Asigne la dirección de n1 a ptrF

Despliegue el valor del objeto apuntado por ptrF

Asigne el valor del objeto apuntado por ptrF a n2

Despliegue el valor de n2

Despliegue la dirección de n1

Despliegue la dirección almacenada en ptrF

Asigne a ptrF la dirección de n2

Asigne al valor del objeto apuntado por ptrF el valor 8.1

Despliegue el valor de n1

Despliegue el valor de n2

Funciones de cadenas estilo Pascal

Las siguientes funciones implementan algunas de las funciones y procedimientos utilizadas en el lenguaje Pascal. Supondremos que las cadenas están declaradas como arreglos de 256 caracteres (incluyendo el \0 de terminación).

Función Descripción

copystr extrae una subcadena de una cadena

deletestr borra una subcadena de una cadena

insert inserta una subcadena dentro de otra

pos busca una subcadena dentro de otra cadena

Función copystr

void copystr(char s[256],char s1[256],int n,int c){ int i,l=strlen(s1); if(l<n)s[0] = '\0'; else{ for(i=0;i<c&&i<l;i++) s[i]=s1[n+i]; s[i]='\0'; }}

Función deletestr

void deletestr(char s[256],int n,int c){ int i=0,l=strlen(s); if(!(l<n)) while(s[i+n]){ s[i+n]=s[i+n+c]; i++; }}

Función insertstr

void insertstr(char s[256],char s1[256],int n){ int i,len=strlen(s); char temp[256]; copystr(temp,s1,n,256); for(i=0;i<len&&i<255;i++) s1[i+n] = s[i]; for(i=0;i<len&&(i+n+len<255);i++) s1[i+n+len] = temp[i]; s1[i+n+len] = '\0';}

Función pos

int pos(char s1[256],char s2[256]){ int len1,len2,i,j1,j2; len1 = strlen(s1); len2 = strlen(s2); for(i=0;i<=len2-len1;i++){ j1 = 0; j2 = i; while(s1[j1]==s2[j2]&&s1[j1]!='\0'){ j1++; j2++; } if(j1==len1)return i; } return -1;}

Ejemplomain(){ char c1[256],c2[256]; strcpy(c1,"hola tal"); printf("c1 = %s\n",c1); strcpy(c2,"que "); printf("c2 = %s\n",c2); insertstr("\"esta es una prueba \"",c1,5); printf("inserta \"esta es una prueba \" en c1 = %s\n",c1); deletestr(c1,0,8); printf("borra de 0 a 8 en c1 = %s\n",c1); deletestr(c1,10,7); printf("borra de 10 a 17 en c1 = %s\n",c1); deletestr(c1,16,5); printf("borra de 16 a 21 en c1 = %s\n",c1); printf("pos de \"una\" = %d\n",pos("una",c1)); printf("pos de \"xxx\" = %d\n",pos("xxx",c1)); printf("pos de \"tal\" = %d\n",pos("tal",c1)); getch();}

Recommended