Tipos genéricos

Puzzle
Avanzado
TypeScript
TypeScript
5 min
Actualizado: 14/02/2025

¡Practica y certifícate!

Retroalimentación
Soluciones
Certificado
Comenzar

Descripción del ejercicio

Este ejercicio práctico ha sido diseñado para que pongas a prueba tu habilidad en TypeScript mediante la resolución de puzzles de código que involucran el uso de tipos genéricos y sus restricciones. A través de diferentes problemas, se busca que completes o modifiques fragmentos de código, utilizando correctamente los genéricos en cada situación.

En TypeScript, los tipos genéricos son extremadamente útiles cuando se trata de escribir código más versátil y escalable. Imagina que quieres escribir una función que trabaje con distintos tipos de datos sin duplicar la lógica para cada tipo. Aquí es donde entran los genéricos, que permiten que una sola función o clase trabaje con múltiples tipos, siempre garantizando que la integridad del tipo se mantenga durante la ejecución del programa.

El objetivo de estos ejercicios tipo puzzle es hacer que identifiques el problema en un fragmento de código genérico y lo resuelvas de manera correcta. Esto te llevará a analizar diferentes tipos de restricciones genéricas, entender cómo pueden aplicarse en diferentes contextos, y encontrar soluciones elegantes que maximicen la eficiencia del código.

¿Por qué practicar con puzzles?

Los ejercicios tipo puzzle te ayudan a desarrollar una mentalidad orientada a la resolución de problemas. En estos desafíos, se te presentarán bloques de código incompletos que deberás corregir o completar. Esto simula problemas que podrías encontrar en situaciones reales al trabajar en proyectos de software, donde los genéricos son utilizados para manejar datos de manera flexible.

Resolver puzzles no solo mejora tu habilidad técnica en TypeScript, sino que también fomenta un enfoque lógico y estructurado para enfrentarte a problemas complejos. Te obliga a pensar de manera crítica sobre cómo funciona el sistema de tipos genéricos en TypeScript y cómo puedes aprovecharlo en diferentes escenarios.

Ejemplos de puzzles

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

  1. Completa el siguiente fragmento de código genérico para que la función devuelva el valor correcto sin errores:
function identidad<T>(valor: T): T {
    // Aquí falta algo...
    return valor;
}
  1. Corrige el código para que aplique correctamente una restricción genérica:
function imprimirPropiedad<T extends { longitud: number }>(objeto: T): void {
    console.log(objeto.longitud);
}
  1. Modifica el código para que acepte dos tipos genéricos y retorne un resultado combinado:
function combinar<T, U>(a: T, b: U): [T, U] {
    // Modifica este bloque...
}

Tipo de reto

· Puzzle de código ·

Cada reto presenta fragmentos de código incompletos que debes llenar correctamente para que el programa funcione. Tendrás que emplear tu conocimiento sobre genéricos y pensar creativamente para resolver cada puzzle.

Modo

· Desafío interactivo ·

Este modo pone a prueba tu destreza para identificar problemas en el código y corregirlos. A través de la práctica continua, te enfrentarás a errores y podrás perfeccionar tu comprensión de los tipos genéricos en TypeScript.

Beneficios adicionales

Aparte de mejorar tu habilidad para escribir código reutilizable y más flexible, resolver puzzles te permitirá desarrollar soluciones creativas a problemas que podrían parecer complejos al principio. Al trabajar con código incompleto, aprenderás a aplicar los principios de los tipos genéricos en situaciones reales, lo que te preparará mejor para enfrentarte a desafíos en proyectos de programación más grandes y complejos.

Intentos

Ilimitados

Duración

5 minutos

Número de preguntas

5

Dificultad

Intermedia-Avanzada

Solución al ejercicio

Contenido bloqueado

¡Desbloquea la solución completa!

Completa el examen 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 exámenes de TypeScript

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

Retroalimentación

Aprende de tus errores

Progreso

Mide tu avance

Certificación

Valida tus habilidades

Únete a miles de desarrolladores mejorando sus habilidades

⭐⭐⭐⭐⭐
4.9/5 valoración