- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
为什么是这段代码
res = []
for i in range(10000):
res[0:0] = [i]
大约比这段代码快十倍?
res = []
for i in range(10000):
res = [i] + res
我预计两者都必须移动所有现有列表元素以将新整数放在零索引处。随着范围的变化,两者看起来确实都是 O(n^2),但切片赋值比添加快得多,这意味着后者的基本操作数量大约是后者的 10 倍。
(是的,两者都无法有效地实现此结果,最好使用 deque
或 append
然后反转结果)
最佳答案
你是对的,在高层次上,循环以相同的方式计算本质上相同的结果。因此,时间差异是由于所用 Python 版本的实现细节所致。没有语言的属性可以解释这种差异。
在 python.org C 实现 (CPython) 中,代码实际上在底层是完全不同的。
res[0:0] = [i]
做它看起来做的事 ;-) res
的全部内容向右移动一个插槽,i
插入左侧创建的孔中结尾。对平台 C 库的 memmove()
函数的一次调用消耗了大量时间,该函数一次性完成转换。现代硬件和 C 库非常擅长快速移动连续的内存片(在 C 级别,Python 列表对象就是)。
res = [i] + res
在幕后做的更多,这主要是由于 CPython 的引用计数。它更像是:
create a brand new list object
stuff `i` into it
for each element of `res`, which is a pointer to an int object:
copy the pointer into the new list object
dereference the pointer to load the int object's refcount
increment the refcount
store the new refcount back into the int object
bind the name `res` to the new list object
decrement the refcount on the old `res` object
at which point the old res's refcount becomes 0 so it's trash
so for each object in the old res:
dereference the pointer to load the int object's refcount
decrement the refcount
store the new refcount back into the int object
check to see whether the new refcount is zero
take the "no, it isn't zero" branch
release the memory for the old list object
更多的原始工作,所有指针取消引用都可以跳过整个内存,这对缓存不友好。
执行
res[0:0] = [i]
跳过大部分内容:它从一开始就知道仅仅移动 res
内容的位置不能对移动对象的引用计数进行任何净更改,因此不会费心去增加或减少任何这些 refcounts。 C 级的 memmove()
几乎就是一团蜡,指向 int 对象的指针都不需要取消引用。不仅原始工作更少,而且对缓存非常友好。
关于Python 列表前置时间复杂度,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/47987581/
我有一个“设置首选项”屏幕。它有一个 ListPreference 和一个 CheckBoxPreference。当我选择 ListPreference 的一项时,我想更改应用程序的日期格式。另外,通
我试图找到创 build 置/配置窗口的示例。单击菜单项中的“选项”操作可启动设置窗口。我想弄清楚如何从主窗口打开第二个窗口。以及新窗口如何将设置信息返回主窗口。尝试使用 QDialog 或一些继承的
我在 Lnux 上有 Qt 应用程序。我想为此创建一个可执行文件/设置以便在 Windows 上分发它并且不需要安装 Qt。我通过包含所有 dll 为此创建了可执行文件但要运行它,用户需要进入文件夹。
我正在尝试创建一个有点动态的 html 类,它根据类末尾包含的数字设置宽度 %。注意:类名将始终以“gallery-item-”开头 示例:div.gallery-item-20 = 20% 宽度 我
关闭。这个问题需要更多focused .它目前不接受答案。 想改进这个问题吗? 更新问题,使其只关注一个问题 editing this post . 关闭 6 年前。 Improve this qu
在我的应用程序中,我想记住一些变量,例如,如果用户登录过一次,那么他们将在下次重新打开应用程序时登录,或者如果他们决定禁用某些提醒,应用程序可以检查该变量是否是错误的,将不再显示该提醒。理想情况下,这
我在 Netbeans 中开发了一个应用程序,它连接到远程计算机的消息队列并发送消息。该应用程序还有其他功能。项目完成后,我清理并构建应用程序,然后 Netbeans 创建一个 jar 文件。 但我的
我创建了一个 Outlook 加载项,需要创建一个设置以使其可分发(我是新手,所以请原谅新手评论) Outlook -2010 Vs -2010 .Net 4.0 我读了一些地方,最简单的方法就是发
这个问题已经有答案了: 已关闭10 年前。 Possible Duplicate: How to make installer pack of Java swing Application Proje
这个问题肯定已经被很多人解决过很多次了,但是经过几个小时的研究,我仍然没有找到我要找的东西。 我有一个 ExportSettings.settings 文件,其中包含一堆设置( bool 值、字符串、
我想为我的项目创建一个安装程序,以便它可以安装在任何电脑上而无需安装头文件。我怎样才能做到这一点? 最佳答案 一般有两种分发程序的方法: 源代码分发(要构建的源代码)。最常见的方法是使用 GNU au
如何在这样的动态壁纸中创 build 置 Activity ? Example Picture 我只用一个简单的文本构建了设置 Activity ,但遇到了一些问题。第一个问题是我不能为此 Activ
我用 GUI 创建了一个简单的软件。它有几个源文件。我可以在我的编辑器中运行该项目。我认为它已经为 1.0 版本做好了准备。但我不知道如何为我的软件创 build 置/安装程序。 源代码是python
我的 SettingsActivity当前扩展了 Android Studio 生成的类,AppCompatPreferenceActivity扩展 PreferenceActivity . Acti
我正在使用 .NET 为 IE 开发工具栏。目前,我使用 gacutil 插入我的 .NET 程序集,并使用 regasm 注册我的 COM 程序集。 我想为项目创建一个设置 (MSI),但我似乎无法
在为设置页面创建 Activity 后,我注意到 if (mCurrentValue !== value) 中的 mCurrentValue !== value 返回警告: Identity equa
我在 Visual Studio 10 中创建了一个项目,该项目使用 Mysql 数据库和 Crystalreports 以及 它。但是我不知道如何进行自动安装 Mysql 和 Crystalrepo
我正在尝试在我的 C# 项目中使用 Sqlite 数据库,并且我在 IDE 中做得很好。我的问题是当我为我的项目制作安装包并安装它时,程序无法访问 sqlite 数据库。我也知道这是因为用户没有访问文
我有一个大型 Web 应用程序(带有 11 子系统的 ErP),我想使用 Microsoft WebPI 为它创建一个设置。 目前,我们每周向客户发送一次应用程序(用于每周更新)。 我们在此应用程序中
所以我对工资单申请的最终查询是 - 如何为薪资申请创 build 置? 我需要知道的一切- 如何将设置项目添加到我现有的解决方案 如何将解决方案中的文件添加到安装项目中,以及添加哪些文件添加和在什么文
我是一名优秀的程序员,十分优秀!