【问题标题】:What's the time complexity for some python list operations?一些 python 列表操作的时间复杂度是多少?
【发布时间】:2020-05-26 18:28:10
【问题描述】:

我知道这是一些基本问题,但我不擅长基本问题。我只知道 for stack pop() 方法以 O(1) 时间弹出最后一个元素。

在python中,它允许弹出列表中的任何位置以及插入元素到任何位置,即list.pop(index)list.insert(index, item)。如果一个列表的长度是n,它们的平均时间复杂度是多少?

另外,list.insert(index, item)list = list[:index] + [item] + list[index:]有区别吗?

非常感谢您的帮助!

【问题讨论】:

标签: python list time-complexity


【解决方案1】:

虽然list.insert(index, item)list = list[:index] + [item] + list[index:] 的作用几乎相同,但python 内置函数list.insert 是一种将项目插入列表的更快方法。 list.insert 更先进,不等同于 list = list[:index] + [item] + list[index:],因为它使用不同的算法并且速度更快。

时间复杂度是O(n),大约是n/2。

【讨论】:

    猜你喜欢
    • 2019-07-15
    • 2015-03-03
    • 2017-02-01
    • 2021-08-03
    • 1970-01-01
    • 2016-08-21
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多