python阶乘函数
1. 用python怎么求15的阶乘
可以用循环loop或递归来(recursion)来解决类似问题
应用loop:
deffactorial_loop(n):
res = 1
for i in range((1,n+1):
res *= i
return res
print factorial(15)
2. recursion
def factorial_recursion(n):
if n <= 1:
return 1
return n*factorial_recursion(n-1)
print factorial_recursion(15)
#>>>1307674368000
此外还可以利用python math库里的factorial函数直接获得:
import math
print math.factorial(15)
#>>>1307674368000
最后请注意如下几点:
以上代码请手动敲入python文档中,直接会考入python不能识别的一些字符导致程序报错。
以上代码仅适用于 Python 2.X, Python 3.X 在某些地方语法会略有不同
2. 求阶乘python方法
def recursion(n):
if n==1:
return 1
else:
return n*recursion(n-1)
list=[]
#定义一个空的列表,将调用递归函数生成的阶乘值追加到列表
print("将1-10的阶乘写入列表,使用sum函数求和") #显示效果明显
for i in range(1,11):
list.append(recursion(i))# 将调用递归函数生成的阶乘值追加到列表
print(sum(list)) #列表求和
sum_0=0
#显示效果明显,center(80,"*")标题放置位置
print("for循环直接调用递归函数求和".center(80,"*"))
for i in range(1,11):
sum_0 +=recursion(i)
print(sum_0)
这是1-10的阶乘求和,你可以参考下!
输出的结果
3. python计算n的阶乘是什么
def factorial(n):
result = n
for i in range(1,n):
result *= i
return result
def main():
print factorial(4)
if __name__ == '__main__':
main()
阶乘介绍:
基斯顿·卡曼(Christian Kramp,1760~1826)于 1808 年发明的运算符号,是数学术语。
一个正整数的阶乘(factorial)是所有小于及等于该数的正整数的积,并且0的阶乘为1。自然数n的阶乘写作n!。1808年,基斯顿·卡曼引进这个表示法。
亦即n!=1×2×3×...×(n-1)×n。阶乘亦可以递归方式定义:0!=1,n!=(n-1)!×n。
4. Python程序求阶乘
deflittle_than_50(x):
ifx<=50:
returnTrue
else:
returnFalse
defcalculate_factorial(x):
ifx<=1:
return1
else:
returnx*calculate_factorial(x-1)
whileTrue:
n=int(input(":"))
iflittle_than_50(n):
break
else:
print("{}isoutofrange,pleaseinputagain!".format(n))
print("Thefactorialof{}is{}".format(n,calculate_factorial(n)))
5. python中n的阶乘的算法
我的代码是
#encoding=utf-8
s=1
n=int(input("请输入一个整数n:"))
for i in range(1,n+1):
s=s*i
print(n,"!=",s)
结果:
python3 a.py
请输入一个整数n:5
5 != 120