→ APM99: py3用四捨五入法得要 round(i/j + 0.0000000000001) 才行 08/10 12:52
推 CaptainH: 你是不是誤會了什麼 要判斷29是不是被7整除 只要他媽的 08/10 12:59
→ CaptainH: 除一下就好 08/10 12:59
推 CaptainH: 四捨入+0.5好就 加一個0.000...1不知道搞什麼鬼 08/10 13:03
→ CaptainH: 或者用ceil/floor 根本沒這問題 08/10 13:04
→ bruce0209: 要判斷29是不是被7整除 我也思考了很久在說啥… 08/10 13:12
→ Django: ????????? 08/10 15:47
推 nknuukyo: 謝謝~ 08/10 16:00
→ nknuukyo: wiki裡有一段python3.6的引碼,不曉得是否方便說明對應 08/10 16:04
→ nknuukyo: 到原程式的關係^^" 08/10 16:04
wiki是一次做全部,而我們用的引理是去判斷一個數是不是質數
所以我們得一個一個慢慢做
類似的程式碼可以改寫如下
#python
import math
def postive(n):
j=1
isprime = True
while isprime:
for j in range(2,math.ceil(n/j)):#也可以用wiki的n (我們得減1)
if( n%j == 0): #wiki是移除,我們跳出
isprime=False
break
if (isprime): #這部分用淺藍字(較瑣碎)就能直接對應P[p]**2 >= P[-1]:
return(n)
#輸入 postive(29) 是質數的話會就會 返回29 ,否則不返回東西
#生出2~120的質數列表來
res =[]
for ii in range(2,120):
res.append(postive(ii))
L = list(filter(None, res))#移除列表中的None
print(L)
→ bruce0209: 樓上是說sieve of Eratosthenes的wiki嗎? 08/10 16:20
→ bruce0209: 如果是的話 wiki裡面那個是用刪除法的 和這邊不太一樣 08/10 16:21
→ bruce0209: 你可以看他wiki裡面附的jpg應該就知道他在做什麼了 08/10 16:22
→ bruce0209: 是說...有程式碼了怎麼不自己trace看看 08/10 16:23
※ 編輯: APM99 (36.239.101.200), 08/10/2017 17:19:44
→ stucode: ... 先不論原本的lemma是什麼 你的code真的是問題滿載 08/10 19:34
→ bruce0209: postive?????? 豆頁女子痛... 08/10 19:37
→ bruce0209: 推薦可以看一下clear code相關書....... 08/10 19:37
→ stucode: isprime就return n 那while isprime:是? 08/10 19:44
→ stucode: 每次call一開始j都是1 那n/j是在表現什麼? 08/10 19:45
推 CaptainH: 愈寫愈錯XDD 平鋪直敘的算法也能寫這麼醜XDD 08/10 20:43