- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
我有一个家庭作业问题是编写一个函数,该函数是类 bagOfWords 的一部分,用于从未排序的列表中删除值的实例。我们可以使用的列表操作不包括 remove()。我们只需要 O(n) 的复杂度,而朴素的算法表现不佳。
我尝试了一种朴素的算法。这是一个太复杂的算法。它使用 list.pop(index) 本身具有 O(n) 复杂度并且它有两个循环。由于我们不允许使用 list.remove() 并且因为列表理解具有相同的复杂性但语法更简洁,所以我试图找到更好的实现。
我认为也许解决方案是快速排序算法,因为如果我首先对列表进行排序,我可能能够以 O(n) 的复杂度完成此操作。但是我如何在没有 pop(index) 的复杂性的情况下删除这个项目?现在我想知道通过 KMP 算法搜索模式是否是解决方案或散列法。
def remove(self, item):
"""Remove all copies of item from the bag.
Do nothing if the item doesn't occur in the bag.
"""
index = 0
while index < len(self.items):
if self.items[index] == item:
self.items.pop(index)
else:
index += 1
复杂度是二次方的。但是,我想要复杂度为 O(n)
编辑:澄清一下,我们实际上只能修改现有列表。
最佳答案
编辑:最简单(也可以说是“正确”)的方法是使用列表理解:
self.items = [x for x in self.items if x != item]
它的复杂度为 O(n),并且比以下选项更快。它也是迄今为止最“pythonic”的。
但是,它确实创建了列表的新副本。如果您实际上不得不修改现有列表,这是我的原始答案:
Here's an "in-place" O(n) algorithm that uses two pointers to collapse the list down, removing the unwanted elements:
ixDst = 0
for ixSrc in range(0, len(items)):
if items[ixSrc] != item:
items[ixDst] = items[ixSrc]
ixDst += 1
del items[ixDst:](See it run here)
The only questionable part is resizing the list down with
del
. I believe that's in-place and "should" be O(1), since the slice we're removing is at the end of the list.
此外,@chepner 在评论中建议了一个更 pythonic 的就地答案(并且更快一点):
self.items[:] = (x for x in self.items if x != item)
感谢@juanpa.arrivillaga 和@chepner 的讨论。
关于python - O(n) 复杂度算法,无需 remove() 方法即可从未排序的列表中删除值的实例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/55464394/
我正在使用 .remove() 方法删除一个 html 元素,同时对于这个元素,我有一个事件处理程序,但它没有被触发。为什么会这样呢?这是jsFiddle和代码:HTML Delete I'm goi
所以我尝试从另一篇文章中编写此代码: while(fscanf(orderFile," %49[^;];%d; %49[^\n]",fileName,&seconds,timeValue) == 3)
我正在阅读 Nicolai M.Josuttis 撰写的“The C++ STL. A Tutorial and References”一书,在专门介绍 STL 算法的一章中,作者陈述如下:如果你调用
是否有一种简单的机制来确定 DownloadManager remove() 何时完成,因为它看起来是部分异步的。该函数几乎立即返回下载表中已删除的条目计数,但实际的文件系统管理似乎被插入了某个后台线
我愿意: getActionBarToolbar().removeView(logoImage); getActionBarToolbar().addView(logoImage, lp); 我得到:
我有类(class)评论一对多关系。在类(class)表中有 id 和 title 列。在 Review 表中,有 id、comment 和 course_id,其中“course_id”作为指向类(
我在 stackoverflow 上阅读了不同的答案,了解如何销毁 wigdet/jQueryObject 并取消绑定(bind)其上的所有事件。 这就是我的想法。 $('选择器').remove()
我有一个由一个线程填充的 byte[] 列表,然后我有另一个线程正在从该列表中读取并通过网络发送项目。 每次我读取线程 2 中的项目时,我都想将其从内存中清除。但是因为我正在使用线程,如果我使用 .r
就算法而言,从连续数组中删除一组元素可以分两部分有效地完成。 将所有不删除的元素移到数组的前面。 将数组标记得更小。 这可以在 C++ 中使用 erase-remove 习惯用法来完成。 vector
我尝试删除包含在 map 中渲染的制造商的 View 。当我单击按钮时,事件 click .ver 被激活,但没有任何反应,并且我收到以下错误:Uncaught TypeError: undefine
场景: 使用 jQuery 2.0.1 构建的应用程序。 您的团队更喜欢原生 JavaScript。 选项有jQuery .remove()和 ChildNode.remove() . 您需要删除节点
最初我有一个像这样的删除功能: function ViewWorkflowDetail(btn, workflowId) { $("#workflowDetailPanel").remov
我正在编写 C++ 代码来解决 Leetcode 中的这个问题:https://leetcode.com/problems/remove-element/ Given an array nums an
根据太阳, "Iterator.remove is the only safe way to modify a collection during iteration; the behavior is
众所周知,从 std::vector 中完全删除所需项的一种好方法是 erase-remove idiom . 如以上链接中所述(截至本文发布日期),在代码中,erase-remove 习惯用法如下所
我在 HashSet 上调用 Iterator.remove() 时遇到问题。 我有一组带有时间戳的对象。在将新项目添加到集合之前,我会遍历集合,识别该数据对象的旧版本并将其删除(在添加新对象之前)。
这段代码: Collection col = new ArrayList(); col.add("a"); col.add("b"); col.add("c");
我试图通过在下面输入来卸载 conda 环境基础, conda env remove -n base 正如我所建议的那样,我尝试通过使用来停用基地 conda deactivate base 我再次尝
我已经对我的 IOS 应用程序进行了质量扫描分析。我收到以下警告: The binary has Runpath Search Path (@rpath) set. In certain cases
这个问题已经有答案了: Properly removing an Integer from a List (8 个回答) 已关闭 4 年前。 我是java新手。看起来很简单,但我不明白为什么会发生这种
我是一名优秀的程序员,十分优秀!