我的代碼:import syssys.setrecursionlimit(10000)findNumber = 0startingnumber = 100000def mainfunc(): global startingnumber, findNumber while(findNumber == 0): print(startingnumber) if (startingnumber % 11 == 0): if (startingnumber % 12 == 0): if (startingnumber % 13 == 0): if (startingnumber % 14) == 0: if (startingnumber % 15 == 0): if (startingnumber % 16 == 0): if (startingnumber % 17 == 0): if (startingnumber % 18 == 0): if (startingnumber % 19 == 0): if (startingnumber % 20 == 0): findNumber=1 else: startingnumber = startingnumber + 10 mainfunc() else: startingnumber = startingnumber + 10 mainfunc() else: startingnumber = startingnumber + 10 mainfunc() else: startingnumber = startingnumber + 10 mainfunc() else: startingnumber = startingnumber + 10 mainfunc() else: startingnumber = startingnumber + 10 mainfunc()這個程序的用途是計算能被1到20的所有數字整除的最小正數我知道這個程序是有效的,因為當我在“startingnumber”中插入正確的數字時,程序會檢測到它并起作用。然而,我的問題是起始值增加了 ≈25,000 然后程序停止工作。例如,如果我將 startingnumber 設置為 10,000,程序將運行到 ≈35,000,然后停止工作。如果我將 startingnumber 設置為 100,000,程序將運行到 ≈125,000 并停止工作。有人能告訴我為什么嗎?我也知道有很多更簡單的方法可以做到這一點,但我計劃在弄清楚為什么這個程序不起作用后繼續研究
1 回答

三國紛爭
TA貢獻1804條經驗 獲得超7個贊
這是解決此問題的一種更加pythonic的方法:
def smallest_divisible(n):
while True:
factor_check = tuple(n%i==0 for i in range(2, 21))
if all(factor_check):
return n
n += factor_check.index(False) + 1
這里,n是起點。如果需要,您可以將其設置為 1。此代碼吐出 232792560。有機會通過跟蹤一些質數來使其更快。
添加回答
舉報
0/150
提交
取消