Reto Filtrado con filter() y find()

Código
Intermedio
JavaScript
Curso de JavaScript
10 min
200 XP
Actualizado: 14/05/2025

¡Programa y certifícate!

Asistente de IA
Solución de código
Certificado
Empezar ejercicio

Descripción

Filtrar y encontrar elementos en una lista de productos según criterios específicos

Implementa dos funciones que trabajen con el siguiente array de productos:

Guarda tu progreso

Inicia sesión para no perder tu progreso y accede a miles de tutoriales, ejercicios prácticos y nuestro asistente de IA.

Progreso guardado
Asistente IA
Ejercicios
Iniciar sesión gratis

Más de 25.000 desarrolladores ya confían en CertiDevs

const products = [
  { id: 1, name: "Laptop", price: 1200, category: "electronics", stock: 15 },
  { id: 2, name: "Smartphone", price: 800, category: "electronics", stock: 0 },
  { id: 3, name: "Headphones", price: 100, category: "accessories", stock: 20 },
  { id: 4, name: "Monitor", price: 300, category: "electronics", stock: 5 },
  { id: 5, name: "Keyboard", price: 50, category: "accessories", stock: 0 },
  { id: 6, name: "Mouse", price: 25, category: "accessories", stock: 10 }
];
  1. Crea una función llamada getAvailableElectronics que utilice el método filter() para devolver un array con todos los productos electrónicos (categoría "electronics") que tengan stock disponible (stock > 0).

  2. Crea una función llamada findCheapestAccessory que utilice el método find() para devolver el primer accesorio (categoría "accessories") con un precio inferior a 60€ y que tenga stock disponible.

Ambas funciones deben ser puras y utilizar exclusivamente los métodos filter() o find() según corresponda.

Solución al ejercicio de programación en JavaScript

Contenido bloqueado

¡Desbloquea la solución completa!

Completa el ejercicio de programación en JavaScript para acceder a la solución paso a paso, explicaciones detalladas y mejores prácticas.

solution.js
JavaScript
1 function solveChallenge ( input ) {
2 // Algoritmo optimizado O(n log n)
3 const data = parseInput ( input );
4 const sorted = data . sort (( a , b ) => a - b );
5
6 // Aplicar técnica de dos punteros
7 let left = 0 , right = sorted . length - 1 ;
8 const result = [];
9
10 while ( left < right ) {
11 const sum = sorted [ left ] + sorted [ right ];
12 if ( sum === target ) {
13 result . push ([ sorted [ left ], sorted [ right ]]);
14 left ++; right --;
15 } else if ( sum < target ) {
16 left ++;
17 } else {
18 right --;
19 }
20 }
21
22 return result ;
23 }
Código completo
Explicaciones
Mejores prácticas
+1.200 developers han resuelto este ejercicio de programación

Practica con ejercicios de programación en JavaScript

Mejora tus habilidades con cientos de ejercicios de práctica, recibe retroalimentación instantánea y obtén tu certificación cuando estés listo.

Asistente de IA

Aprende de tus errores

Progreso

Mide tu avance

Certificación

Valida tus habilidades

Únete a miles de desarrolladores mejorando sus habilidades en JavaScript

⭐⭐⭐⭐⭐
4.9/5 valoración