Generics

Código
Avanzado
Go
Curso de Go
30 min
75 XP
Actualizado: 01/11/2024

¡Programa y certifícate!

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

Ejercicio de programación: Generics

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

Tipo: Ejercicio de código 30 minutos estimados 75 puntos de experiencia

Información adicional del ejercicio

Implementa una pila genérica en Go usando las características de genéricos para gestionar elementos de cualquier tipo.

Contenido del ejercicio

Implementa un tipo genérico en Go que represente una pila (estructura LIFO - Last In, First Out). La pila debe permitir almacenar elementos de cualquier tipo utilizando genéricos.

Tu tarea es:

  1. Definir un tipo genérico Pila[T] que represente la pila.
  2. Implementar los siguientes métodos para Pila[T]:
    • Apilar(elemento T): agrega un elemento a la cima de la pila.
    • Desapilar() T: elimina y devuelve el elemento de la cima de la pila.
    • EstaVacia() bool: devuelve true si la pila está vacía, o false en caso contrario.
  3. Asegúrate de que la pila funcione correctamente con cualquier tipo de dato.

Notas:

  • No utilices paquetes adicionales; solo puedes usar los paquetes estándar de Go.

Ejemplo de uso:

func main() {
    var pila Pila[int]
    pila.Apilar(10)
    pila.Apilar(20)
    fmt.Println(pila.Desapilar()) // Debería imprimir 20
    fmt.Println(pila.Desapilar()) // Debería imprimir 10
    fmt.Println(pila.EstaVacia()) // Debería imprimir true
}

Lección relacionada

Este ejercicio está relacionado con la lección "Generics" de Go. Te recomendamos revisar la lección antes de comenzar.

Ver lección relacionada

Más ejercicios de Go

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

Ver más ejercicios de Go

Solución al ejercicio de programación en Go

Contenido bloqueado

¡Desbloquea la solución completa!

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

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 Go

⭐⭐⭐⭐⭐
4.9/5 valoración