- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我想检查给定的 x
位于区间[0,a-1]
.作为一个懒惰的编码员,我写了
x in range(a)
并且(因为那段代码在 4.5 嵌套循环中)很快就会遇到性能问题。我测试了它,结果确实是 n in range(n)
的运行时间在于 O(n),给予或接受。我实际上认为我的代码会被优化为 x >= 0 and x < a
但似乎并非如此。即使我修复了 range(a)
提前时间不会变得恒定(尽管它会改善很多)- 请参阅旁注。
我应该使用 x >= 0 and x < a
吗?并且从不写x in range(a)
以后再?有没有更好的写法?
旁注:
如果我尝试以下操作:
i = range(a)
...
x in i
因此范围是固定的,我只测量 x in i
的运行时间,我仍然在 O(x) 中获得运行时间(假设 a
足够大)。
n in xrange(n)
的运行时也在于 O(n)。最佳答案
range
的问题在 Python 2 中,它创建了一个 list
的值,所以 x in range(a)
将创建一个列表并线性扫描该列表。 xrange
应该是一个生成器,但也快不了多少;可能仍然只是线性扫描值,而不是先创建整个列表。
In [2]: %timeit 5*10**5 in range(10**6 + 1) # Python 2
10 loops, best of 3: 18.1 ms per loop
In [3]: %timeit 5*10**5 in xrange(10**6 + 1) # Python 2
100 loops, best of 3: 6.21 ms per loop
在Python 3 , range
更聪明,不仅不创建整个列表,而且还提供了 contains
的快速实现检查。
In [1]: %timeit 5*10**5 in range(10**6 + 1) # Python 3
1000000 loops, best of 3: 324 ns per loop
更快,恕我直言,更具可读性:使用比较链:
In [2]: %timeit 0 <= 5*10**5 < 10**6 + 1 # Python 2 or 3
10000000 loops, best of 3: 46.6 ns per loop
Should I use
x >= 0 and x < a
and never write x in range(a) ever again? Is there an even better way of writing it?
“否”、“视情况而定”和"is"。你不应该使用 x >= 0 and x < a
因为0 <= x < a
更短且更容易解析(对于弱小的人),并被解释为 (0 <= x) and (x < a)
.你不应该使用 in range
在 Python 2 中,但在 Python 3 中,您可以根据需要使用它。
不过,我更喜欢比较链,因为 a <= x < b
关于边界比 x in range(a, b)
更明确(如果 x == b
会怎么样?),这可以防止许多差一错误或 +1
填充范围。
另外,请注意 0 <= x < a
与 x in range(0, a)
不完全相同, 作为 range
将只包含整数值,即 1.5 in range(0, 5)
是False
,而 0 <= 1.5 < 5
是True
,这可能不是你想要的。此外,使用 range
您可以使用 1
以外的步骤,例如5 in range(4, 10, 2)
是False
,但也可以使用纯数学来实现,例如作为(4 <= x < 10) and (x - 4 % 2 == 0)
.
关于python - python 2 中的 `in range` 构建 --- 工作太慢,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49001152/
我创建了以下 sub 来简单地说明问题。我将事件工作表的范围 A2:E10 分配给范围变量。然后,对于另一个范围变量,我将这个范围的子范围,单元格 (1, 1) 分配给 (3, 3)。 我原以为这将包
我使用正则表达式来搜索以下属性返回的纯文本: namespace Microsoft.Office.Interop.Word { public class Range {
我正在开发一个宏来突出显示某些行/单元格以供进一步审查。一些值/空白将以红色突出显示,其他以橙色突出显示,而整行应为黄色。我从上一个问题中得到了一些帮助,并添加了更多细节,它工作得几乎完美,但我被困在
这个问题在这里已经有了答案: What is the difference between range and xrange functions in Python 2.X? (28 个答案) 关闭
我在尝试运行脚本时遇到这个奇怪的错误,代码似乎是正确的,但似乎 python (3) 不喜欢这部分: def function(x): if int
我正在编写一种算法,将一些数据写入提供的输出范围(问题的初始文本包括具体细节,这将评论中的讨论转向了错误的方向)。我希望它在 API 中尽可能接近标准库中的其他范围算法。 我查看了 std::rang
这按预期工作: #include #include int main() { auto chunklist = ranges::views::ints(1, 13) | ranges::vie
我这里有一个字符串,我正在尝试对其进行子字符串化。 let desc = "Hello world. Hello World." var stringRange = 1..' 的值转换为预期的参数类型
我有一个高级搜索功能,可以根据日期和时间查询记录。我想返回日期时间范围内的所有记录,然后从该范围内返回我想将结果缩小到一个小时范围(例如 2012 年 5 月 1 日 - 2012 年 5 月 7 日
Go 中的 range 函数和 range 关键字有什么区别? func main(){ s := []int{10, 20, 30, 40, 50, 60, 70, 80, 90}
如果我有一个范围,如何将其拆分为一系列连续的子范围,其中指定了子范围(存储桶)的数量?如果没有足够的元素,则应省略空桶。 例如: splitRange(1 to 6, 3) == Seq(Range(
我正在开发 VSTO Excel 项目,但在管理 Range 对象时遇到一些问题。 实际上,我需要知道当前选定的范围是否与我存储在列表中的另一个范围重叠。所以基本上,我有 2 个 Range 实例,我
在即将推出的 C++20 系列中,将有 range concept具有以下定义: template concept range = __RangeImpl; // exposition-only de
希望有人能回答我的问题。我在 VHDL 代码中遇到了这个命令,但不确定它到底做了什么。有人可以澄清以下内容吗? if ( element1 = (element1'range => '0')) the
可以将范围嵌套在范围中吗?使用范围内的变量?因为我想取得一些效果。为了说明这个问题,我有以下伪代码: for i in range(str(2**i) for i in range(1,2)):
我想在 2 个日期之间创建一个范围,并且我的范围字段有时间 damage_list = Damage.objects.filter(entry_date__range=(fdate, tdate))
在下面的代码中 #include #include #include int main() { std::unordered_mapm; m["1"]=1; m["2"]=2
我试图为我的电子表格做一个简单的循环,它循环遍历一个范围并检查该行是否为空,如果不是,则循环遍历一系列列并检查它们是否为空,如果是则它设置一个消息。 问题是每次它通过循环 ro.value 和 col
我在将一个工作簿范围中的值分配给当前工作簿中的某个范围时遇到问题。当我使用 Range("A1:C1") 分配我的范围时,此代码工作正常,但是当我使用 Range(Cells(1,1),Cells(1
我改写了原来的问题。 Sub s() Dim r As Range Set r = ActiveSheet.Range("B2:D5") Debug.Print r.Rows.Count
我是一名优秀的程序员,十分优秀!