def recursion(n):
在西固等地區(qū),都構建了全面的區(qū)域性戰(zhàn)略布局,加強發(fā)展的系統(tǒng)性、市場前瞻性、產(chǎn)品創(chuàng)新能力,以專注、極致的服務理念,為客戶提供成都網(wǎng)站建設、成都網(wǎng)站設計 網(wǎng)站設計制作定制網(wǎng)站建設,公司網(wǎng)站建設,企業(yè)網(wǎng)站建設,高端網(wǎng)站設計,網(wǎng)絡營銷推廣,成都外貿(mào)網(wǎng)站建設公司,西固網(wǎng)站建設費用合理。
if n==1:
return 1
else:
return n*recursion(n-1)
list=[]
#定義一個空的列表,將調(diào)用遞歸函數(shù)生成的階乘值追加到列表
print("將1-10的階乘寫入列表,使用sum函數(shù)求和") #顯示效果明顯
for i in range(1,11):
list.append(recursion(i))# 將調(diào)用遞歸函數(shù)生成的階乘值追加到列表
print(sum(list)) #列表求和
sum_0=0
#顯示效果明顯,center(80,"*")標題放置位置
print("for循環(huán)直接調(diào)用遞歸函數(shù)求和".center(80,"*"))
for i in range(1,11):
sum_0 +=recursion(i)
print(sum_0)
這是1-10的階乘求和,你可以參考下!
輸出的結(jié)果
第一種:普通的for循環(huán)
第二種:reduce()函數(shù)
第三種:factorial()函數(shù)
第四種:遞歸調(diào)用
一個整數(shù)的階乘就是所有小于等于該數(shù)字的正整數(shù)的積。舉例說明3的階乘就是3*2*1。
電腦:WIN10
軟件:ISO
軟件:python
1、用def代碼創(chuàng)建一個函數(shù),名稱為func,參數(shù)為n
def func(n):
2、創(chuàng)建一個變量res,賦值為函數(shù)的參數(shù)n,代碼如下:
res = n。
3、然后寫入for range循環(huán),具體代碼如下:
for i in range(1,n):
4、接下來在for循環(huán)當中進行計算并且返回res,具體代碼如下:
res *= i
return res。
5、用print代碼打印輸出3的階乘,代碼如下:
print(func(3))。
6、以上代碼實現(xiàn)了階乘的運算,另外我們還可以用遞歸的方式進行。代碼如下:
def func1(n):
if n==1:
return 1
else:
return n *func1(n-1)
print(func1(3))
遞歸方式是函數(shù)自己調(diào)用自己。