Reto closures

Código
Avanzado
Rust
Curso de Rust
3 min
200 XP
Actualizado: 17/05/2025

¡Programa y certifícate!

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

Ejercicio de programación: Reto closures

Este ejercicio de programación está diseñado para poner a prueba tus conocimientos en Rust. Es un ejercicio avanzado que pondrá a prueba tus conocimientos expertos.

Tipo: Ejercicio de código 3 minutos estimados 200 puntos de experiencia

Información adicional del ejercicio

Crear una función que utilice una closure para filtrar números pares de una lista

Contenido del ejercicio

Implementa una función llamada filtrar_con_closure que reciba dos parámetros: un vector de números enteros y una closure. La función debe aplicar la closure a cada elemento del vector y devolver un nuevo vector que contenga solo los elementos para los que la closure devuelve true.

Luego, en la función main(), crea un vector con los números del 1 al 10 y utiliza la función filtrar_con_closure con una closure que filtre solo los números pares. Imprime el resultado usando println!.

Para empezar, puedes definir la función con esta firma:

fn filtrar_con_closure<F>(numeros: &[i32], filtro: F) -> Vec<i32>
where
    F: Fn(&i32) -> bool
{
    // Tu código aquí
}

Lección relacionada

Este ejercicio está relacionado con la lección "Funciones anónimas closures" de Rust. Te recomendamos revisar la lección antes de comenzar.

Ver lección relacionada

Más ejercicios de Rust

Explora más ejercicios de programación en Rust para mejorar tus habilidades y obtener tu certificación.

Ver más ejercicios de Rust

Solución al ejercicio de programación en Rust

Contenido bloqueado

¡Desbloquea la solución completa!

Completa el ejercicio de programación en Rust 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 Rust

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 Rust

⭐⭐⭐⭐⭐
4.9/5 valoración