Niewiele osób wie, ale Python oferuje bezpośrednią funkcję, która może obliczyć silnię liczby bez konieczności pisania całego kodu w celu obliczenia silni.
Naiwna metoda obliczania silni
Python3
# Python code to demonstrate naive method> # to compute factorial> n> => 23> fact> => 1> for> i> in> range> (> 1> , n> +> 1> ):> > fact> => fact> *> i> print> (> 'The factorial of 23 is : '> , end> => '')> print> (fact)> |
>
>Wyjście
The factorial of 23 is : 25852016738884976640000>
Złożoność czasowa: NA)
Przestrzeń pomocnicza: O(1)
Korzystanie z funkcji math.factorial()
Metoda ta zdefiniowana jest w matematyka moduł Pythona. Ponieważ ma wewnętrzną implementację typu C, jest szybki.
wskaźnik dereferencji c
math.factorial(x) Parameters : x : The number whose factorial has to be computed. Return value : Returns the factorial of desired number. Exceptions : Raises Value error if number is negative or non-integral.>
Python3
# Python code to demonstrate math.factorial()> import> math> print> (> 'The factorial of 23 is : '> , end> => '')> print> (math.factorial(> 23> ))> |
>
>Wyjście
The factorial of 23 is : 25852016738884976640000>
Złożoność czasowa: NA)
Przestrzeń pomocnicza: O(1)
Wyjątki w math.factorial()
- Jeśli podana liczba jest ujemna:
Python3
# Wyjątki (liczba niecałkowa)
importuj matematykę
print(silnia 5.6 to : , end=)
# zgłasza wyjątek
print(math.silnia(5.6))
>
>
Wyjście:
Traceback (most recent call last): File '/home/f29a45b132fac802d76b5817dfaeb137.py', line 9, in print (math.factorial(-5)) ValueError: factorial() not defined for negative values>
- Jeśli podana liczba jest wartością niecałkową:
Python3
>
>
Wyjście:
Traceback (most recent call last): File '/home/3987966b8ca9cbde2904ad47dfdec124.py', line 9, in print (math.factorial(5.6)) ValueError: factorial() only accepts integral values>