Estructuras de datos y algoritmos en Python
Miriam Antona
Software engineer
$n!$
$n!=n$ · $(n-1)$ · $(n-2)$ · $...$ · $1$
$5!=$ $5$ · $4$ · $3$ · $2$ · $1=120$
def factorial(n):
result = 1
while n > 1:
result = n * result
n -= 1
return result
factorial(5)
120
$n!= n$ · $(n-1)!$
def factorial_recursion(n):
return n * factorial_recursion(n-1)
def factorial_recursion(n): if n == 1:return 1else:return n * factorial_recursion(n-1)
print(factorial_recursion(5))
120
factorial(5)factorial(5) -> empieza factorial(4)factorial(4) -> empieza factorial(3)
factorial(5)factorial(5) -> empieza factorial(4)factorial(4) -> empieza factorial(3)factorial(3) -> empieza factorial(2)
factorial(5)factorial(5) -> empieza factorial(4)factorial(4) -> empieza factorial(3)factorial(3) -> empieza factorial(2)factorial(2) -> empieza factorial(1)
factorial(5)factorial(5) -> empieza factorial(4)factorial(4) -> empieza factorial(3)factorial(3) -> empieza factorial(2)factorial(2) -> empieza factorial(1)
factorial(1) terminafactorial(2) termina
factorial(1) terminafactorial(2) termina
factorial(1) terminafactorial(2) terminafactorial(3) termina
factorial(1) terminafactorial(2) terminafactorial(3) terminafactorial(4) termina
factorial(1) terminafactorial(2) terminafactorial(3) terminafactorial(4) terminafactorial(5) termina
factorial(1) terminafactorial(2) terminafactorial(3) terminafactorial(4) terminafactorial(5) termina
Estructuras de datos y algoritmos en Python