En este post vamos a ver cómo contar consonantes de una cadena en C, es decir, vamos a recorrer una cadena y contar cuántas consonantes tiene.
Recordemos que una consonante (sin ser un experto en el lenguaje español) es algo que está dentro del abecedario pero no es una vocal.
Por lo tanto para poder contar consontantes de una cadena en C o mejor dicho, obtener la cantidad de consonantes que una cadena tiene hay que recorrer la cadena y comparar cada carácter, así como cuando contamos las vocales.
Primero debemos recorrer la cadena y obtener cada carácter. A ese carácter le aplicamos dos filtros.
isalpha
que viene dentro de ctype.h
Si ambos filtros se cumplen, podemos decir que el carácter es consonante.
A continuación tenemos la función que dice si un carácter es vocal, la misma nos ayuda para contar consonantes de una cadena en C:
// Función que indica si un carácter es vocal, ¿hace falta más explicación?
int esVocal(char letra) {
// Convertir a mayúscula para evitar hacer más comparaciones
char letraEnMayuscula = (char) toupper(letra);
return letraEnMayuscula == 'A' ||
letraEnMayuscula == 'E' ||
letraEnMayuscula == 'I' ||
letraEnMayuscula == 'O' ||
letraEnMayuscula == 'U';
}
La convertimos a mayúscula usando toupper
para que las comparaciones sean menos.
Ahora que ya tenemos la función ayudante, podemos implementar la función llamada contarConsonantes
que recibe una cadena (bueno, un apuntador al primer elemento de un arreglo de tipo char
, pero queremos usar términos simples) y devuelve un entero con la cantidad de consonantes.
int contarConsonantes(char cadena[]) {
int consonantes = 0;// Almacenar la cantidad de consonantes
int i = 0;// El índice para recorrer la cadena
while (cadena[i]) {
// Si es del alfabeto pero no es vocal
if (isalpha(cadena[i]) && !esVocal(cadena[i])) {
consonantes++;
}
i++;
}
return consonantes;
}
Tenemos la variable i
que nos ayuda a recorrer la cadena, en cada paso comprobamos si es del abecedario y si no es vocal, en caso de que se cumplan, simplemente aumentamos la cantidad de consonantes.
Al terminar de recorrer la cadena devolvemos el número de consonantes.
Ahora veamos un ejemplo de uso de la función para poder contar consonantes de una cadena en ANSI C. Queda así:
/**
* Contar consonantes de una cadena en C usando simples comparaciones
* y la función isalpha
*
* @author parzibyte
* https://parzibyte.me/blog
*
* */#include <stdio.h> // Para printf
#include <ctype.h> // Para toupper y isalpha
// Función que indica si un carácter es vocal, ¿hace falta más explicación?
int esVocal(char letra) {
// Convertir a mayúscula para evitar hacer más comparaciones
char letraEnMayuscula = (char) toupper(letra);
return letraEnMayuscula == 'A' ||
letraEnMayuscula == 'E' ||
letraEnMayuscula == 'I' ||
letraEnMayuscula == 'O' ||
letraEnMayuscula == 'U';
}
int contarConsonantes(char cadena[]) {
int consonantes = 0;// Almacenar la cantidad de consonantes
int i = 0;// El índice para recorrer la cadena
while (cadena[i]) {
// Si es del alfabeto pero no es vocal
if (isalpha(cadena[i]) && !esVocal(cadena[i])) {
consonantes++;
}
i++;
}
return consonantes;
}
int main() {
char cadena[] = "Hola mundo (hoy es 21 de octubre), vamos a contar las consonantes en C desde parzibyte.me";
int consonantes = contarConsonantes(cadena);
printf("La cadena '%s' \ntiene %d consonantes", cadena, consonantes);
return 0;
}
En el método main
estamos invocando a la función contarConsonantes
y después con printf
imprimimos los resultados.
Recuerda que la cadena podría ser proporcionada por el usuario usando por ejemplo fgets.
Por cierto, aquí puedes ver cómo contar las vocales y aquí más sobre ANSI C.
Ya te enseñé cómo convertir una aplicación web de Vue 3 en una PWA. Al…
En este artículo voy a documentar la arquitectura que yo utilizo al trabajar con WebAssembly…
En un artículo anterior te enseñé a crear un PWA. Al final, cualquier aplicación que…
Al usar Comlink para trabajar con los workers usando JavaScript me han aparecido algunos errores…
En este artículo te voy a enseñar cómo usar un "top level await" esperando a…
Ayer estaba editando unos archivos que son servidos con el servidor Apache y al visitarlos…
Esta web usa cookies.