为了减少计算时间,我想在双循环条件中添加一些类似双条件的东西:
for i WHERE i % 2 == 0 in range(0,(realbignumber/2)):
if i % realbignum == 0: do some stuff
我大部分不确定在forloop中执行“ where”类型语句的正确方法?我确信可能有更好的方法来减少计算时间(我正在尝试对realbignum进行素数分解),并且将从获取除数列表开始,然后检查素数.一旦我弄清了i%2 == 0的“ where”子句,我便计划实施类似“ for i,而我在范围内占优”的东西.我正在python 2中工作,但也可以使用python 3方法.
解决方法:
使用生成器表达式,像这样
for i in (num for num in xrange(realbignumber / 2) if num % 2 == 0):
对于这种特殊情况,您实际上可以在xrange本身中指定step参数,如下所示
for i in xrange(0, realbignumber / 2, 2):
请注意,我使用了xrange而不是range函数.因为Python 2.x中的range函数创建了一个数字列表,而xrange仅创建了xrange object.所以xrange适用于非常长的范围,因为它具有很高的内存效率.
如果输入数字太大而无法放入Python的int中,则可以在生成器的帮助下滚动自己的简化范围函数,如下所示
>>> def my_range(start, stop, step=1):
... current = start
... while current < stop:
... yield current
... current += step
...
>>> [num for num in my_range(0, 10)]
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
或者,您可以使用ShadowRanger所示的itertools版本,如下所示
>>> from itertools import islice, count
>>> def bigxrange(start, stop, step=1):
... return islice(count(start, step), (stop - start + step - 1))
...
>>> list(bigxrange(0, 10))
[0, 1, 2, 3, 4, 5, 6, 7, 8, 9]
标签:python-2-7,range,python
来源: https://codeday.me/bug/20191027/1944759.html