scipy.special.
factorial#
- scipy.special.factorial(n, exact=False, extend='zero')[source]#
- 一个数或一组数的阶乘。 - 非负整数 n 的阶乘是小于或等于 n 的所有正整数的乘积 - n! = n * (n - 1) * (n - 2) * ... * 1 - 参数:
- nint 或 float 或 complex(或类似数组)
- n!的输入值。复数值需要- extend='complex'。默认情况下,- n < 0的返回值是 0。
- exactbool,可选
- 如果 - exact设置为 True,则使用整数算术精确计算答案,否则使用伽马函数近似(更快,但产生浮点数而不是整数)。默认为 False。
- extendstring,可选
- 可以是 - 'zero'或- 'complex'之一;这决定了如何处理- n<0的值 - 默认情况下它们是 0,但可以选择加入阶乘的复数扩展(见下文)。
 
- 返回值:
- nfint 或 float 或 complex 或 ndarray
- n的阶乘,作为整数、浮点数或复数(取决于- exact和- extend)。数组输入作为数组返回。
 
 - 注释 - 对于 - exact=True的数组,阶乘仅计算一次,针对最大的输入,并在该过程中计算每个其他结果。如有必要,输出 dtype 将增加到- int64或- object。- 当 - exact=False时,阶乘使用伽马函数近似计算(伽马函数也是复数扩展的定义)\[n! = \Gamma(n+1)\]- 示例 - >>> import numpy as np >>> from scipy.special import factorial >>> arr = np.array([3, 4, 5]) >>> factorial(arr, exact=False) array([ 6., 24., 120.]) >>> factorial(arr, exact=True) array([ 6, 24, 120]) >>> factorial(5, exact=True) 120