Python階乘求和的代碼怎么寫

這篇文章將為大家詳細(xì)講解有關(guān)Python階乘求和的代碼怎么寫,文章內(nèi)容質(zhì)量較高,因此小編分享給大家做個(gè)參考,希望大家閱讀完這篇文章后對(duì)相關(guān)知識(shí)有一定的了解。

創(chuàng)新互聯(lián)主營(yíng)烏蘭網(wǎng)站建設(shè)的網(wǎng)絡(luò)公司,主營(yíng)網(wǎng)站建設(shè)方案,重慶APP開發(fā)公司,烏蘭h5成都小程序開發(fā)搭建,烏蘭網(wǎng)站營(yíng)銷推廣歡迎烏蘭等地區(qū)企業(yè)咨詢

Python階乘求和的方法

題目描述:

獲得用戶輸入的整數(shù)n,輸出 1!+2!+…+n!的值。

如果輸入數(shù)值為0、負(fù)數(shù)、非數(shù)字或非整數(shù),輸出提示信息:輸入有誤,請(qǐng)輸入正整數(shù)。

方法一:

#factTest1def main():  a = input()  sum = 0  if a.isdigit():    n = eval(a)    if n > 0:      fact = 1      for i in range(1, n+1):        fact *= i        sum += fact      print(sum)    else:      print("輸入有誤,請(qǐng)輸入正整數(shù)")  else:    print("輸入有誤,請(qǐng)輸入正整數(shù)")main()

方法二:遞歸思想

#factTest2import syssys.setrecursionlimit(5000)def getSum(i):  sum = 0  if i==0:    return 0  else:    for x in range(1,i+1):      sum += fact(x)    return sumdef fact(m):  if m==0:    return 1  else:    return m*fact(m-1)def main():  n = input()  if n.isdigit():    a = eval(n)    if a>0:      result = getSum(a)      print(result)    else:      print("輸入有誤,請(qǐng)輸入正整數(shù)")  else:    print("輸入有誤,請(qǐng)輸入正整數(shù)")main()

問題總結(jié):

當(dāng)使用遞歸方法求1024的階乘時(shí),出現(xiàn)了一個(gè)異常:RecursionError: maximum recursion depth exceeded in comparison,超出了遞歸的最大深度。一些網(wǎng)友提到Python中默認(rèn)的最大遞歸深度為1000,但在實(shí)際測(cè)試中,我的電腦到997的時(shí)候就出現(xiàn)異常了,不知道這是由什么決定的。因此,為了能夠計(jì)算1024的階乘,需要為最大遞歸深度賦予一個(gè)更大的值。這里可以采用以下方法:

import syssys.setrecursionlimit(5000) #修改為5000

另外,也可以查看最大遞歸深度:

import syssys.getrecursionlimit() # output:1000

關(guān)于Python階乘求和的代碼怎么寫就分享到這里了,希望以上內(nèi)容可以對(duì)大家有一定的幫助,可以學(xué)到更多知識(shí)。如果覺得文章不錯(cuò),可以把它分享出去讓更多的人看到。

網(wǎng)站名稱:Python階乘求和的代碼怎么寫
標(biāo)題來源:http://muchs.cn/article6/joppig.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供移動(dòng)網(wǎng)站建設(shè)、品牌網(wǎng)站設(shè)計(jì)ChatGPT、網(wǎng)站排名、品牌網(wǎng)站制作動(dòng)態(tài)網(wǎng)站

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)

成都做網(wǎng)站