- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
def primes(n):
if n==2: return [2]
elif n<2: return []
s=range(3,n+1,2)
mroot = n ** 0.5
half=(n+1)/2-1
i=0
m=3
while m <= mroot:
if s[i]:
j=(m*m-3)/2
s[j]=0
while j<half:
s[j]=0
j+=m
i=i+1
m=2*i+3
return [2]+[x for x in s if x]
你好,我在这里找到了这个功能http://code.activestate.com/recipes/366178-a-fast-prime-number-list-generator/我卡住了。我不明白这一点。我认为它使用了素数的某些属性,但所有这些单字母变量都非常神秘。你能透露一些信息吗?
我的理解是:mroot 是要检查素数的数字的限制而且我知道该函数将列表 s 更改为 0,以标记倍数。后面的list comprehesion我也看懂了,s我也看懂了。
但为什么是一半? j是什么?什么是米?
你能给点意见吗?
最佳答案
逐行分割:
def primes(n):
if n==2: return [2]
此函数返回素数列表 <= n
.所以如果n == 2
,该列表仅包含 2 个。很简单。
elif n<2: return []
同样,这里没有小于 2 的素数,所以返回一个空列表。
s=range(3,n+1,2)
所以 s
是从 3 开始到 n + 1
的奇数列表. s
代表 sieve——这是一个筛选算法,这意味着复合(非素数)数字将从列表中筛选出来。实际上,它们将被“划掉”。有关筛选算法的详细说明,请参见下文。
mroot = n ** 0.5
因为它是一个筛子,我们可以在达到 n
的平方根后停止算法。 .
half=(n+1)/2-1
这是s长度的明确公式;它可以替换为 len(s)
, 但对于较大的 n 值可能需要更长的时间来计算。这对于终止算法的某些部分也很有用。
i=0
m=3
I 是我们的索引;我只是简单地通过筛子,检查每个值。如果值为 0
,则该数字已被“划掉”,因为它不是质数。 m
只是 s[i]
的值在任何特定时刻;后面一行保持更新。
while m <= mroot:
if s[i]:
自 s[i]
评估为 True
,它还没有从列表中划掉。这意味着它是主要的!所以现在我们必须找出列表中的哪些数字是 s[i]
的倍数-- 它们都是非素数,应该从列表中划掉。
j=(m*m-3)/2
s[j]=0
现在乐趣开始了。因为筛子不是连续数的列表,而是奇数的列表,所以我们必须找出质数的倍数位于 s
中的位置。 .在这种情况下,我们的素数是 3
, 所以我们需要找到 9, 15, 21, 27... 的索引(我们不必找到 6, 12, 18... 因为它们是偶数,所以不在列表中)。这种寻找索引的特殊技术非常聪明,因为作者已经弄清楚,一旦某个特定素数的所有倍数都被划掉,就可以跳过它们。这意味着我们素数的第一个未划掉的倍数实际上是该素数的平方。 (例如,如果质数是 7,则 7 * 3 = 21 和 7 * 5 = 35 已经被划掉,所以我们必须处理的第一个 7 的倍数是 7 * 7。)从某种意义上说,很容易看出 9 在 s
中的位置是 (9 - 3)//2(其中//是楼层划分)。
while j<half:
s[j]=0
j+=m
现在又回到了简单的状态。我们找到了 9 个;现在我们必须找到 15 = 9 + 3 + 3。因为 s
仅包含奇数,它的长度是包含每个数字的列表的一半;跳过 6 然后,我们只需要将 3 添加到 j
.我们这样做只要 j
小于 half
-- 也就是说,只要j
小于s
的长度.
i=i+1
m=2*i+3
同样,简单 -- i
只是列表的索引,而 m
是最初存在的数字的值。 (您可以对其进行测试以了解原因:[2 * i + 3 for i in range(10)]
。)
return [2]+[x for x in s if x]
然后 瞧 -- 从筛子中过滤掉零,在 [2] 前面加上一个素数列表。
这个算法最令人困惑的地方在于作者走的捷径,这使得运行速度更快,但却混淆了基本概念。 (事实上 ,还有更多的捷径可以走,但那是另一篇文章了。)这是一个更简单的筛子,显示了基本思想:
>>> numbers = range(40)
>>> numbers[1] = 0 # 1 isn't prime
>>> for i in numbers:
... if i:
... for j in range(i + i, len(numbers), i):
... numbers[j] = 0
...
>>> [n for n in numbers if n]
[2, 3, 5, 7, 11, 13, 17, 19, 23, 29, 31, 37]
总而言之,第一个数字是这样的:
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9, 10...]
然后...
[0, 0, 2, 3, 4, 5, 6, 7, 8, 9, 10...]
[0, 0, 2, 3, 0, 5, 0, 7, 0, 9, 0...]
[0, 0, 2, 3, 0, 5, 0, 7, 0, 0, 0...]
等等。
关于python - 解释这个素数生成器函数,我无法理解[python],我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/6274215/
C语言sscanf()函数:从字符串中读取指定格式的数据 头文件: ?
最近,我有一个关于工作预评估的问题,即使查询了每个功能的工作原理,我也不知道如何解决。这是一个伪代码。 下面是一个名为foo()的函数,该函数将被传递一个值并返回一个值。如果将以下值传递给foo函数,
CStr 函数 返回表达式,该表达式已被转换为 String 子类型的 Variant。 CStr(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CSng 函数 返回表达式,该表达式已被转换为 Single 子类型的 Variant。 CSng(expression) expression 参数是任意有效的表达式。 说明 通常,可
CreateObject 函数 创建并返回对 Automation 对象的引用。 CreateObject(servername.typename [, location]) 参数 serv
Cos 函数 返回某个角的余弦值。 Cos(number) number 参数可以是任何将某个角表示为弧度的有效数值表达式。 说明 Cos 函数取某个角并返回直角三角形两边的比值。此比值是
CLng 函数 返回表达式,此表达式已被转换为 Long 子类型的 Variant。 CLng(expression) expression 参数是任意有效的表达式。 说明 通常,您可以使
CInt 函数 返回表达式,此表达式已被转换为 Integer 子类型的 Variant。 CInt(expression) expression 参数是任意有效的表达式。 说明 通常,可
Chr 函数 返回与指定的 ANSI 字符代码相对应的字符。 Chr(charcode) charcode 参数是可以标识字符的数字。 说明 从 0 到 31 的数字表示标准的不可打印的
CDbl 函数 返回表达式,此表达式已被转换为 Double 子类型的 Variant。 CDbl(expression) expression 参数是任意有效的表达式。 说明 通常,您可
CDate 函数 返回表达式,此表达式已被转换为 Date 子类型的 Variant。 CDate(date) date 参数是任意有效的日期表达式。 说明 IsDate 函数用于判断 d
CCur 函数 返回表达式,此表达式已被转换为 Currency 子类型的 Variant。 CCur(expression) expression 参数是任意有效的表达式。 说明 通常,
CByte 函数 返回表达式,此表达式已被转换为 Byte 子类型的 Variant。 CByte(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CBool 函数 返回表达式,此表达式已转换为 Boolean 子类型的 Variant。 CBool(expression) expression 是任意有效的表达式。 说明 如果 ex
Atn 函数 返回数值的反正切值。 Atn(number) number 参数可以是任意有效的数值表达式。 说明 Atn 函数计算直角三角形两个边的比值 (number) 并返回对应角的弧
Asc 函数 返回与字符串的第一个字母对应的 ANSI 字符代码。 Asc(string) string 参数是任意有效的字符串表达式。如果 string 参数未包含字符,则将发生运行时错误。
Array 函数 返回包含数组的 Variant。 Array(arglist) arglist 参数是赋给包含在 Variant 中的数组元素的值的列表(用逗号分隔)。如果没有指定此参数,则
Abs 函数 返回数字的绝对值。 Abs(number) number 参数可以是任意有效的数值表达式。如果 number 包含 Null,则返回 Null;如果是未初始化变量,则返回 0。
FormatPercent 函数 返回表达式,此表达式已被格式化为尾随有 % 符号的百分比(乘以 100 )。 FormatPercent(expression[,NumDigitsAfterD
FormatNumber 函数 返回表达式,此表达式已被格式化为数值。 FormatNumber( expression [,NumDigitsAfterDecimal [,Inc
我是一名优秀的程序员,十分优秀!