→ bigpigbigpig: i/2 在 Python 2 中是整數除法,5/2 = 2 而非 2.5 06/09 16:23
→ bigpigbigpig: p與xrange的對映關係研究一下,黃色那行就是在實作 06/09 16:48
→ bigpigbigpig: Sieve of Eratosthenes,把 i 的倍數全部刪除 06/09 16:49
我主要是語法看不懂, python 3 剛接觸, 很多語法和類 C 語言不同
p[i*i/2::i] 這句完全不知道是什麼意思
[False] * ((n-i*i-1)/(2*i)+1)
我只知道是要做出 ((n-i*i-1)/(2*i)+1) 數量的 False
我知道 埃式篩 的操作過程
不過語法看不懂, 所以黃色那句才完全看不懂
※ 編輯: WingedDragon (140.112.25.105), 06/11/2016 20:14:38
→ bigpigbigpig: p[i*i/2::i]→從i*i/2到結尾,每隔i個間隔取值,即 06/11 23:55
→ bigpigbigpig: index為i*i/2(=a),a+i,a+2*i,...,直到p的結尾, 06/11 23:56
→ bigpigbigpig: 個人覺得這樣的最佳化有點過頭,找序列的slice算子 06/11 23:58
那 [False] * ((n-i*i-1)/(2*i)+1) 是如何和那些數字對應 ?
是一個 i 就產生一次, 還是每一個間隔產生一次 ?
※ 編輯: WingedDragon (140.112.4.192), 06/12/2016 21:10:16
→ zerof: [False] 會把篩出來的位置都換成 False, 要下一次篩到 True 06/15 02:22
→ zerof: 才會再執行 [False] * ____ 06/15 02:23