- mongodb - 在 MongoDB mapreduce 中,如何展平值对象?
- javascript - 对象传播与 Object.assign
- html - 输入类型 ="submit"Vs 按钮标签它们可以互换吗?
- sql - 使用 MongoDB 而不是 MS SQL Server 的优缺点
我想知道为什么 Python 中默认的 list
没有任何 shift
、unshift
方法。也许有一个明显的原因,比如列表在内存中的排序方式。
所以目前,我知道我可以使用 append
在列表末尾添加一个项目,并使用 pop
从末尾删除一个元素。但是,我只能使用列表连接来模仿缺少的 shift
或 unshift
方法的行为。
>>> a = [1,2,3,4,5]
>>> a = [0] + a # Unshift / Push
>>> a
[0,1,2,3,4,5]
>>> a = a[1:] # Shift / UnPush
>>> a
[1,2,3,4,5]
我错过了什么吗?
最佳答案
Python 列表针对快速固定长度操作进行了优化,并为 pop(0)
和 insert(0, v)
操作带来 O(n) 内存移动成本更改基础数据表示的大小和位置。实际上,CPython 中的“列表”数据类型与许多其他语言可能称为列表(例如链接列表)的工作方式不同 - 它的实现与其他语言可能称为 array 的方式更相似,虽然这里也有一些不同。
您可能对 collections.deque
感兴趣,这是一个类似列表的容器,两端都有快速追加和弹出。
Deques support thread-safe, memory efficient appends and pops from either side of the deque with approximately the same O(1) performance in either direction.
它提供了您似乎在名称 appendleft
下询问的缺失方法和 popleft
:
appendleft(x)
Add x to the left side of the deque.
popleft()
Remove and return an element from the left side of the deque.If no elements are present, raises an
IndexError
.
当然有权衡:在双端队列的中间附近建立索引或插入/删除很慢。事实上 deque.insert(index, object)
甚至是不可能的 before Python 3.5 ,您需要旋转、插入/弹出和旋转回来。双端队列也不支持切片,对于类似的功能,你必须写一些烦人的东西,例如itertools.islice
代替。
关于 deque
与 list
数据结构的优缺点的进一步讨论,请参阅 How are deques in Python implemented, and when are they worse than lists?
关于python - 为什么 Python 的列表没有 shift/unshift 方法?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/34210969/
我有一个函数,可以保存 div 的子级列表,以便在它们移动时保持它们的原始顺序 带有子对象的对象是这样构建的: $('#container').data( 'list', $('#container'
我正在尝试将一个循环中的项目添加到我的“storedCompletion”数组的开头,但由于某种原因它只是继续循环并使浏览器崩溃。 我不明白为什么,因为在遍历数组中的每个对象后,它会检查对象 ID 是
var _array=[]; var someint=44; var somevalue='a string'; var u=[someint]; _array.unshift(u); _array[
所以我在React Native中有一个选择器,该项目基于api,并且api包含像这样的对象数组 [{"code": "N", "description": "正常", "id": 1, "note"
router.route = function (alias, pattern, action, constraints) { if (2 === arguments.length)
我的问题和这个问题一样: https://laracasts.com/discuss/channels/vue/vue-unshift-only-repeats-the-last-item 我有一个这
如何实现类似 Array unshift() 方法这样的方法来创建一个新数组?基本上类似于 Array concat() 方法,但不是将新项目放在末尾,而是将其放在开头。 最佳答案 如果您对要放置在新
关闭。这个问题是opinion-based 。目前不接受答案。 想要改进这个问题吗?更新问题,以便 editing this post 可以用事实和引文来回答它。 . 已关闭 9 年前。 Improv
link: function(scope, elm, attrs, ctrl) { ctrl.$parsers.unshift(function(viewValue) {
如何使用“unshift()”将数字倒置添加到数组?? 我想要一个数组 = {2018, 2017, 2016, 2015, ... , 1999}。因为'2018'是今年,'1999'是我喜欢的歌手
我正在阅读 Crockford 的 JavaScript:The Good Parts,我无法理解他在他的书中所做的 unshift 方法的重新实现。这是代码: Array.method('unshi
我正在尝试实现一个函数来将一个项目添加到数组的开头,而不使用 unshift 或 splice 方法,只是 array.length。到目前为止,我所做的一切都只是覆盖索引 0 处已经存在的内容。任何
ad.unshift()中的内容是什么意思,这里的content是什么意思。我已经阅读了 w3schools 的教程。但是他们没有提到任何关于 unshift 背后的内容。此处的任何帮助将不胜感激。
我正在尝试创建一个函数,它接受一个数组并返回偶数在奇数之前的数组。我想我应该遍历数组并用模检查每个数字的整除性。如果它是偶数,我会将该数字移到数组的前面并继续。 我已经删除了 unshift 来记录它
我想在数组的副本上取消移位,但原始数组也会修改。这是为什么? var array1 = [1, 2, 3] var array2 = array1 array2.unshift(4, 5) conso
我有一个二维数组: var sH = [['two'],['three']] 我想将“一”添加到开始/顶部,以便我的数组最终为 [['one'],['two'],['three']] 使用unshi
我正在使用 angularjs,我有这行代码: // Get our elements var elements = angular.element(options.animation.element
我使用 julia 1.4,并运行以下代码: using PyCall using JLD using ArgParse using Pandas @pyimport networkx as nx @
我正在构建一个自定义指令来匹配两个输入字段。因此,使用 ctrl.$parsers.unshift 会引发错误无法读取未定义的属性“unshift”。无法弄清楚出了什么问题。顺便说一句,我正在使用 A
我写了一篇简短的 Codepen,其中我试图在保留原始数组的同时更改临时数组,但我的两个数组都被更改了。 有人可以解释一下问题是什么吗? var x = ["x"]; abc(x); function
我是一名优秀的程序员,十分优秀!