Recursión

Código
Avanzado
Java
Curso de Java
10 min
200 XP
Actualizado: 06/04/2025

¡Programa y certifícate!

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

Ejercicio de programación: Recursión

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

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

Información adicional del ejercicio

Implementar desde cero un método recursivo de cola para calcular el factorial de un entero sin emplear bucles ni librerías adicionales.

Contenido del ejercicio

Crea un único archivo en Java que incluya un método factorialRecursivo(int n) que aplique recursión de cola para devolver el factorial del número n. 

No uses bucles ni métodos externos para el cálculo: la única forma de repetición permitida es la recursión. 

Asegúrate de definir un caso base que detenga la recursión y de que la última operación que realice tu método sea la llamada recursiva. 

Puedes imprimir el resultado en la salida estándar o devolverlo directamente desde el método main para comprobar su correcto funcionamiento.

Lección relacionada

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

Ver lección relacionada

Más ejercicios de Java

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

Ver más ejercicios de Java

Solución al ejercicio de programación en Java

Contenido bloqueado

¡Desbloquea la solución completa!

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

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 Java

⭐⭐⭐⭐⭐
4.9/5 valoración