java

Factorial recursivo e iterativo en Java

Hoy veremos dos formas de calcular el factorial en Java. La primera utiliza un ciclo while para obtener el factorial de un número, y la segunda utiliza recursividad o recursión.

Factorial con recursión y ciclo while en Java

Esas dos maneras para sacar el factorial las pondremos en unas funciones separadas que recibirán un dato de tipo long y devolverán igualmente un long.

Algoritmo para calcular factorial en Java

Para calcular el factorial en Java se declara una variable que será el resultado; después se hace un ciclo en donde se va restando 1 al número del que se sacará el factorial y en cada iteración se multiplica el factorial por el número.

El ciclo se rompe cuando el número deja de ser mayor que 1. Lo mismo pasa en la recursividad.

En ambas funciones se comprueba si es menor o igual que cero y en caso de que sí, se devuelve 1. Esto viene por una ley matemática que no explicaré ahora, basta con saberlo.

Factorial iterativo o con ciclos en Java

Veamos el enfoque que usa un ciclo while. Como lo dije en el algoritmo, el ciclo se rompe cuando el número deje de ser mayor a 1. La función queda así:

See the gist on github.

Se hace el ciclo, algunas comprobaciones y al final se devuelve el factorial. Todo esto en una función que se puede llamar desde cualquier lugar.

Factorial recursivo en Java

Para sacar el factorial de un número en Java usando recursión (cuando la función se llama a sí misma) se llama a la función con el número que se recibe pero restándole 1. Es decir, se multiplica el actual por lo que regresa la función pero se le pasa el número -1.

La manera en la que se rompe la recursividad es cuando el número es menor o igual a 1, pues se regresa 1.

El código queda así:

See the gist on github.

Probar algoritmos y funciones para calcular el factorial

Podemos implementar el siguiente código en el método main de Java:

See the gist on github.

Ese código va a imprimir el factorial del 0 al 19 usando un ciclo. De esta manera veremos si calculamos bien el factorial tanto de manera recursiva como de manera iterativa o con ciclos.

Prueba el código sin salir del navegador:

¿Quieres aprender más sobre Java? haz click aquí. También puedes ver más algoritmos.

Encantado de ayudarte


Estoy disponible para trabajar en tu proyecto, modificar el programa del post o realizar tu tarea pendiente, no dudes en ponerte en contacto conmigo.

No te pierdas ninguno de mis posts

Suscríbete a mi canal de Telegram para recibir una notificación cuando escriba un nuevo tutorial de programación.
parzibyte

Programador freelancer listo para trabajar contigo. Aplicaciones web, móviles y de escritorio. PHP, Java, Go, Python, JavaScript, Kotlin y más :) https://parzibyte.me/blog/software-creado-por-parzibyte/

Entradas recientes

Imprimir PDF con Bot de Telegram

La impresión de un PDF en cualquier impresora se puede automatizar con un bot de…

4 días hace

Enviar mensaje con bot de Telegram usando JavaScript (lado del cliente)

Hoy te enseñaré cómo enviar un mensaje a un usuario desde un bot de Telegram…

5 días hace

PHP: incrustar imagen en base64

El día de hoy te enseñaré algo muy sencillo pero útil al programar con PHP:…

5 días hace

Plugin ESC POS – Actualización 3.4.0: imprimir HTML

El plugin para imprimir en impresoras térmicas alcanza hoy su versión 3.4.0 agregando soporte para…

6 días hace

JavaScript (lado del cliente): leer pixeles de imagen

En ocasiones es necesario leer los pixeles y colores de una imagen con JavaScript del…

2 semanas hace

PHP y JavaScript: llenar select con AJAX

Siguiendo con los tutoriales de listas desplegables o select con JavaScript, vamos a ver cómo…

2 semanas hace

Esta web usa cookies.