階乘:也是數學里的一種術語;階乘指從1乘以2乘以3乘以4一直乘到所要求的數;在表達階乘時,就使用“!”來表示。如h階乘,就表示為h!;階乘一般很難計算,因為積都很大。
一、參考解法:
分析:1、階乘的計算:用遞歸函數實現是比較好的方案,先定義一個遞歸函數實現求階乘功能。
def recursion(n): #'定義遞歸函數實現求階乘功能'
if n==1:
return 1
else:
return n*recursion(n-1)
分析:2、求和:(1)可以直接求和 。(2)也可以定義一個列表,將for遍歷得到的階乘結果追加到列表,然后使用sum()函數求和。
Sum=0
print("for循環直接調用遞歸函數求和".center(80,"*"))
for i in range(1,21):
Sum +=recursion(i)
print(Sum)
列表求和方案:
list=[] #定義一個空的列表,將調用遞歸函數生成的階乘值追加到列表
print("將1-20的階乘寫入列表,使用sum函數求和".center(80,"*"))
for i in range(1,21):
list.append(recursion(i))# 將調用遞歸函數生成的階乘值追加到列表
print(sum(list)) #列表求和
【完整源代碼】以及結果:
def recursion(n): #'定義遞歸函數實現求階乘功能'
if n==1:
return 1
else:
return n*recursion(n-1)
list=[ ] #定義一個空的列表,將調用遞歸函數生成的階乘值追加到列表
for i in range(1,21):
list.append(recursion(i))# 將調用遞歸函數生成的階乘值追加到列表
print(sum(list)) #列表求和
Sum = 0
for i in range(1,21):
Sum +=recursion(i)
print(Sum)
結果:
2561327494111820313
二、參考解法:
使用函數 math.factorial()
import math Sum=0 num = int(input('請輸入一個數字:')) for i in range(1,num+1): F=math.factorial(i) Sum +=F print('階乘之和:',Sum)
三、參考解法:
Sum=0
factorial=1
num = int(input('請輸入一個數字:'))
for i in range(1,num+1):
factorial = factorial*i
Sum +=factorial
print('階乘之和:',Sum)
