Reto enums

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 enums

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 un enum para representar los estados de un semáforo con métodos para cambiar de estado

Contenido del ejercicio

Crea un enum llamado Semaforo con tres variantes: Rojo, Amarillo y Verde. Implementa un método llamado siguiente_estado que devuelva el siguiente estado del semáforo siguiendo la secuencia: Rojo → Verde → Amarillo → Rojo. Además, implementa un método llamado describir que devuelva un String con la descripción del estado actual: "Detenerse" para Rojo, "Precaución" para Amarillo y "Avanzar" para Verde.

Para probar tu implementación, crea una función main que inicialice un semáforo en estado Rojo, y luego cambie de estado tres veces, imprimiendo la descripción después de cada cambio.

Lección relacionada

Este ejercicio está relacionado con la lección "Enumeraciones enums" 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