En este post veremos cómo encontrar o buscar un elemento dentro de un ArrayList de Java. Para ello veremos el método contains
e indexOf
, además del método equals
de las clases.
El método más fácil y que funciona en la mayoría de lenguajes es recorrer la lista en cuestión y comparar cada elemento con la búsqueda.
Pero en Java, un ArrayList provee el método contains
e indexOf
que podemos usar para estos propósitos. Lo único que hay que hacer es sobrescribir dos métodos de los objetos.
Y no te preocupes, si no te gusta, al final dejaré un ejemplo para poder buscar un elemento en ArrayList de Java simplemente recorriendo el ArrayList.
Si queremos saber simplemente si un elemento existe dentro de un ArrayList invocamos a contains
que devuelve un booleano.
/*
Buscar elemento en ArrayList de Java
usando contains
https://parzibyte.me/blog
*/import java.util.ArrayList;
class Main {
public static void main(String[] args) {
ArrayList<String> canciones = new ArrayList<>();
// Le agregamos datos
canciones.add("Beds are burning");
canciones.add("It's only rock 'n' Roll (But I like it)");
canciones.add("Ashes to ashes");
String busqueda = "Ashes to ashes";
boolean existe = canciones.contains(busqueda);
if (existe) {
System.out.println("El elemento SÍ existe en la lista");
} else {
System.out.println("El elemento no existe");
}
}
}
Si el elemento existe, devuelve true
, si no, false
.
Este método devuelve -1
o el índice que el elemento ocupa dentro del ArrayList. Funciona para saber si el elemento existe dentro del ArrayList y para saber cuál índice tiene al mismo tiempo.
Su uso es el siguiente:
/*
Buscar elemento en ArrayList de Java
https://parzibyte.me/blog
*/import java.util.ArrayList;
class Main {
public static void main(String[] args) {
ArrayList<String> canciones = new ArrayList<>();
// Le agregamos datos
canciones.add("Beds are burning");
canciones.add("It's only rock 'n' Roll (But I like it)");
canciones.add("Ashes to ashes");
String busqueda = "Ashes to ashes";
int indice = canciones.indexOf(busqueda);
if (indice != -1) {
System.out.println("La búsqueda está en el índice " + indice);
} else {
System.out.println("El elemento no existe");
}
}
}
En este caso funciona porque String ya es una clase definida y ya tiene su método equals
, así que no hay problema al llamar a indexOf
pasándole la otra cadena.
Ahora vamos a ver un ejemplo para buscar elemento en ArrayList de Java usando clases propias. Solo hay que sobrescribir el método equals
y hashCode
.
¿Has escuchado del método equals en Java? sirve para comparar que dos objetos son iguales, ya que por ejemplo para comparar cadenas en Java se utiliza ese método en lugar del operador ==
.
Este método sirve para indicar si dos objetos son iguales, y podemos definirlo a nuestro gusto, la forma más básica es comparar cada propiedad. Veamos un ejemplo de la clase Producto:
class Producto {
private String codigo, nombre;
private float precio;
public Producto() {
}
public Producto(String codigo, String nombre, float precio) {
this.codigo = codigo;
this.nombre = nombre;
this.precio = precio;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Producto producto = (Producto) o;
return Float.compare(producto.precio, precio) == 0 &&
codigo.equals(producto.codigo)
&& nombre.equals(producto.nombre);
}
@Override
public int hashCode() {
return Objects.hash(codigo, nombre, precio);
}
}
Aunque el código puede parecer confuso, el principio es el mismo: comparar propiedad con propiedad; además de comparar la clase. La mayoría de ocasiones tu IDE puede ayudarte a generar estos métodos.
Una vez que hemos sobrescrito esos métodos, podemos usar indexOf
y contains
.
Veamos el siguiente código:
/*
Buscar elemento en ArrayList de Java
usando contains, además de una clase
propia
https://parzibyte.me/blog
*/import java.util.ArrayList;
import java.util.Objects;
class Main {
public static void main(String[] args) {
ArrayList<Producto> productos = new ArrayList<>();
// Le agregamos datos
productos.add(new Producto("123", "Gansito", 20f));
productos.add(new Producto("456", "Galletas Chokis", 12f));
productos.add(new Producto("7879876456", "Doritos", 5.5f));
Producto busqueda = new Producto("123", "Gansito", 20f);
boolean existe = productos.contains(busqueda);
if (existe) {
System.out.println("El elemento SÍ existe en la lista");
} else {
System.out.println("El elemento no existe");
}
}
}
class Producto{
private String codigo, nombre;
private float precio;
public Producto() {
}
public Producto(String codigo, String nombre, float precio) {
this.codigo = codigo;
this.nombre = nombre;
this.precio = precio;
}
@Override
public boolean equals(Object o) {
if (this == o) return true;
if (o == null || getClass() != o.getClass()) return false;
Producto producto = (Producto) o;
return Float.compare(producto.precio, precio) == 0 &&
Objects.equals(codigo, producto.codigo) &&
Objects.equals(nombre, producto.nombre);
}
@Override
public int hashCode() {
return Objects.hash(codigo, nombre, precio);
}
}
Además de definir la clase, creamos un ArrayList de tipo Producto. Como hemos sobrescrito correctamente ambos métodos, todo funciona bien.
Como hemos sobrescrito ambos métodos de la clase, podemos usar normalmente el método indexOf.
Para terminar este post vamos a ver cómo realizar una búsqueda manual, ya lo dije, recorriendo el ArrayList y comparando manualmente.
Voy a usar de nuevo la clase Producto pero ahora no me hace falta hashCode
ni equals
, solo algunos getters. La clase queda así:
class Producto {
private String codigo, nombre;
private float precio;
public Producto() {
}
public Producto(String codigo, String nombre, float precio) {
this.codigo = codigo;
this.nombre = nombre;
this.precio = precio;
}
public String getCodigo() {
return codigo;
}
}
Lo siguiente es definir el ArrayList con la búsqueda:
ArrayList<Producto> productos = new ArrayList<>();
// Le agregamos datos
productos.add(new Producto("123", "Gansito", 20f));
productos.add(new Producto("456", "Galletas Chokis", 12f));
productos.add(new Producto("7879876456", "Doritos", 5.5f));
Producto busqueda = new Producto("123", "Gansito", 20f);
Al final se hace la búsqueda recorriendo el ArrayList. En este caso voy a buscar únicamente si ya existe un producto con el mismo código, no importa que el nombre o el precio no coincidan.
// Voy a buscar únicamente comparando el código
boolean encontrado = false;
for (int x = 0; x < productos.size(); x++) {
Producto p = productos.get(x);
if (p.getCodigo().equals(busqueda.getCodigo())) {
encontrado = true;
break; // Terminar ciclo, pues ya lo encontramos
}
}
// Al terminar el ciclo comprobamos si se movió la variable
if (encontrado) {
System.out.println("El producto existe");
} else {
System.out.println("El producto NO existe");
}
El código completo queda así:
/*
Buscar elemento en ArrayList manualmente
https://parzibyte.me/blog
*/import java.util.ArrayList;
class Main {
public static void main(String[] args) {
ArrayList<Producto> productos = new ArrayList<>();
// Le agregamos datos
productos.add(new Producto("123", "Gansito", 20f));
productos.add(new Producto("456", "Galletas Chokis", 12f));
productos.add(new Producto("7879876456", "Doritos", 5.5f));
Producto busqueda = new Producto("123", "Gansito", 20f);
// Voy a buscar únicamente comparando el código
boolean encontrado = false;
for (int x = 0; x < productos.size(); x++) {
Producto p = productos.get(x);
if (p.getCodigo().equals(busqueda.getCodigo())) {
encontrado = true;
break; // Terminar ciclo, pues ya lo encontramos
}
}
// Al terminar el ciclo comprobamos si se movió la variable
if (encontrado) {
System.out.println("El producto existe");
} else {
System.out.println("El producto NO existe");
}
}
}
class Producto {
private String codigo, nombre;
private float precio;
public Producto() {
}
public Producto(String codigo, String nombre, float precio) {
this.codigo = codigo;
this.nombre = nombre;
this.precio = precio;
}
public String getCodigo() {
return codigo;
}
}
Si no te ha quedado claro, te dejo un vídeo explicativo:
Solo debo agregar una pequeña nota y es que al buscar manualmente dentro del ArrayList, la lógica puede ser movida a una función para tener un código más limpio y ordenado como vimos en la búsqueda binaria.
Te invito a leer más sobre Java.
Hoy te voy a presentar un creador de credenciales que acabo de programar y que…
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…
Esta web usa cookies.
Ver comentarios
Excelente aportación, las mejores explicaciones y ejemplos de programación que he visto jamás!! . A nivel didáctico eres un crack, un 10, Sigue así!!
Y como le hago para encontrar un elemento dentro de un objeto... no se si me explico...
Ejemplo:
Agrego este objeto a mi ArrayList
Producto: Gansito
ID: 123456
Marca: Marinela
y que solamente me devuelva el ID
Como hago es?
Excelente muchas gracias, la comparación es exitosa colocando la lógica en la entidad.
Así es, con eso podemos comparar cualquier objeto implementando métodos personalizados.
No olvides seguirme y compartir para más tutoriales. Saludos :)
ERES DIOS!!!!!!!!! GRACIAS