作者热门文章
- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我正在使用 Python 3.2.3。反向迭代列表的最快方法是什么? [::-1]、reversed、list.reverse() 或者其他方式?我正在处理大约 5e6 个元素的列表,所以我真的需要避免复制列表。
最佳答案
>>> from timeit import Timer
>>> t = Timer('[x for x in l[::-1]]', 'l = list(range(100000))')
>>> t.timeit(number=1000)
5.549649953842163
>>> t = Timer('l.reverse(); [x for x in l]', 'l = list(range(100000))')
>>> t.timeit(number=1000)
4.548457145690918
>>> t = Timer('[x for x in reversed(l)]', 'l = list(range(100000))')
>>> t.timeit(number=1000)
4.428632974624634
结论:在包含 100000 个项目的列表中,reversed() 比 l.reverse() 快一点。如果您实际上没有遍历整个列表,这当然更正确,如果您多次使用该列表,它就不再正确。
l[::-1]
自引入 reversed()
的 2.4 以来已过时。
关于python - 需要尽可能快地反向迭代 Python 列表,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/11486922/
我知道在 KDB 中,如果您有一个列表,例如... l:`apples`oranges`pears` 您可以像下面这样进行 N 次随机选择: 9?l 但是如何尽可能均匀地选择列表中的每个项目? 最佳答
我真的厌倦了它。我有一个高级 Web 应用程序依赖于大量 Javascript 库(jQuery、jQueryUI、OpenLayers、highcharts、EJSChart 等等)。不用说,Int
我是一名优秀的程序员,十分优秀!