階乘-->>數學用n! = n*(n-1)*(n-2)*(n-3)*....*3*2*1,0的階乘也是1,本人無法演繹,只能簡單的從1開始
第一種:推導式+循環遍歷列表內每個元素相乘
def factorial(n): li =[i for i in range(1,n+1)] #li = [1,2,3,4] 推導式,形成一個列表,從1開始至n+1結束(左閉右開,n須+1) a = 1 # a = 1開始計算,如果從0開始,0×任何整數都為0,對此題無太大意義 for i in li: # 遍歷列表內元素,循環需要遍歷完才會進行下一步 a = a *i # =左邊的a為右邊相乘的賦值,第一次=右邊為1*1 則a =1,第二次=右邊為1*2則=左邊a=2,第三次=右邊為2*3則=左邊a=6,....... return a print(factorial(4))
第二種:調用functools模塊reduce的累計算
from functools import reduce #reduce 累計算,格式為reduce(函數,序列)序列:array 列表、元組、字典 def factorial(n): li = [i for i in range(1,n+1)] #同第一種推導式,形成列表 return reduce((lambda x,y:x*y),li) # 匿名函數lambda print(factorial(4))
第三種:遞歸
def factorial(n): if n <=1: return 1 return n*factorial(n-1) print(factorial(5))
第四種:模塊numpy中的prod
import numpy def func(n): Array = [i for i in range(1,n+1)] return numpy.prod(Array) print(func(1))