En este artículo sobre programación vamos a ver cómo contar vocales de una cadena en Java.
Es decir, dada una cadena, contar cuántas vocales tiene, sin importar si son mayúsculas o minúsculas.
Para codificar este algoritmo vamos a ver una función que dice si un carácter es vocal, y vamos a usar un HashMap de Java para almacenar el conteo.
Comencemos viendo una función que nos dice si un carácter es una vocal. No es el más efectivo, pero funciona.
Lo que hace es convertir el carácter a cadena, luego lo convierte a minúscula con toLowerCase y finalmente comprueba si está en la cadena “aeiou” con el método contains
.
private static boolean esVocal(char letra) {
return "aeiou".contains(String.valueOf(letra).toLowerCase());
}
Si no te interesa la frecuencia de vocales y solo quieres saber cuántas hay en la cadena, el código quedaría así, sin mapa:
int vocales = 0;
for (int x = 0; x < cadena.length(); x++) {
char letraActual = cadena.charAt(x);
if (esVocal(letraActual)) vocales++;
}
System.out.printf("Vocales en '%s': %d", cadena, vocales);
Continúa leyendo si quieres saber cómo contar la frecuencia de cada vocal.
Vamos a usar la estructura de datos Mapa en Java, a través del HashMap. Si no entiendes mucho sobre el tema, por favor dale un vistazo a mi artículo sobre HashMap en Java.
Para aplicar un truco, las vocales serán la clave y el conteo será el valor. Así que será de tipo String, Integer.
Por defecto, todos los conteos estarán en 0.
// Crear e inicializar mapa
// Tutorial de mapas: https://parzibyte.me/blog/2020/01/07/hashmap-java-tutorial-ejemplos/
HashMap<String, Integer> hashMap = new HashMap<>();
hashMap.put("a", 0);
hashMap.put("e", 0);
hashMap.put("i", 0);
hashMap.put("o", 0);
hashMap.put("u", 0);
También necesitamos la cadena a la que le vamos a realizar el conteo:
// La cadena a la que le contaremos las vocales
String cadena = "Mi nombre es Luis Cabrera. Tengo un blog en parzibyte.me/blog y aunque no es mi lenguaje favorito, me gusta Java";
Estamos preparados para recorrer la cadena, tomar cada letra, comprobar si es vocal y en caso de que sí, aumentar su conteo.
El código queda así:
// Recorremos la cadena letra por letra y vemos si es una vocal
for (int x = 0; x < cadena.length(); x++) {
char letraActual = cadena.charAt(x);
if (esVocal(letraActual)) {
// La clave es la vocal en sí, pero en minúscula
String clave = String.valueOf(letraActual).toLowerCase();
// Aumentamos el conteo en esa clave
hashMap.put(clave, hashMap.get(clave) + 1);
}
}
Si es vocal (línea 4) entonces aumentamos el valor en uno (línea 8). Ahora solo basta recorrer el HashMap para mostrar los resultados.
Una vez que he colocado las funciones y líneas por separado, veamos cómo trabajan todas juntas. Queda así:
/*
* Archivo: ContarVocalesJava.java
* Clase: ContarVocalesJava
* Autor: parzibyte
* Fecha: 1/7/20 10:16 PM
* Visita https://parzibyte.me/blog para más tutoriales sobre Java
*/
import java.util.HashMap;
public class ContarVocalesJava {
public static void main(String[] args) {
// La cadena a la que le contaremos las vocales
String cadena = "Mi nombre es Luis Cabrera. Tengo un blog en parzibyte.me/blog y aunque no es mi lenguaje favorito, me gusta Java";
// Crear e inicializar mapa
// Tutorial de mapas: https://parzibyte.me/blog/2020/01/07/hashmap-java-tutorial-ejemplos/
HashMap<String, Integer> hashMap = new HashMap<>();
hashMap.put("a", 0);
hashMap.put("e", 0);
hashMap.put("i", 0);
hashMap.put("o", 0);
hashMap.put("u", 0);
// Recorremos la cadena letra por letra y vemos si es una vocal
for (int x = 0; x < cadena.length(); x++) {
char letraActual = cadena.charAt(x);
if (esVocal(letraActual)) {
// La clave es la vocal en sí, pero en minúscula
String clave = String.valueOf(letraActual).toLowerCase();
// Aumentamos el conteo en esa clave
hashMap.put(clave, hashMap.get(clave) + 1);
}
}
System.out.printf("Resultados para '%s':\n", cadena);
//Imprimir resultados
for (HashMap.Entry<String, Integer> entry : hashMap.entrySet()) {
System.out.printf("Vocal: %s. Conteo: %d\n", entry.getKey(), entry.getValue());
}
}
private static boolean esVocal(char letra) {
return "aeiou".contains(String.valueOf(letra).toLowerCase());
}
}
Yo lo he ejecutado y funciona perfectamente; si no funciona, deja tu comentario.
Hace algún tiempo hice la implementación de este algoritmo en C, dale una leída si quieres.
Por otro lado, te invito a leer más sobre Java en mi blog.
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.