请问在Python中实现队列pop,push的O(1)方法是?

nuptxxp 2013-10-19 07:49:09
我在网上看到有人说用list模拟队列,但感觉如果list是类似C数组,肯定是达不到pop O(1)

还有看到使用 Queue模块的Queue.Queue的,但是没有说明时间复杂度(好像Python很多数据结构都不说明内在实现时间复杂度)

堆栈应该用list实现pop 和push都是O(1)吧,有专门的模块实现这样的数据结构吗?
...全文
567 3 打赏 收藏 转发到动态 举报
AI 作业
写回复
用AI写文章
3 条回复
切换为时间正序
请发表友善的回复…
发表回复
Bird_1989 2013-12-18
  • 打赏
  • 举报
回复
我先在做的就是这个东西,头大
nuptxxp 2013-10-19
  • 打赏
  • 举报
回复
引用 1 楼 panghuhu250 的回复:
collections.deque, 在两头的操作都是O(1),但取中间的值的话是O(n)。 python数据结构的时间复杂度:https://wiki.python.org/moin/TimeComplexity
谢谢~~
panghuhu250 2013-10-19
  • 打赏
  • 举报
回复
collections.deque, 在两头的操作都是O(1),但取中间的值的话是O(n)。 python数据结构的时间复杂度:https://wiki.python.org/moin/TimeComplexity

37,743

社区成员

发帖
与我相关
我的任务
社区描述
JavaScript,VBScript,AngleScript,ActionScript,Shell,Perl,Ruby,Lua,Tcl,Scala,MaxScript 等脚本语言交流。
社区管理员
  • 脚本语言(Perl/Python)社区
  • WuKongSecurity@BOB
加入社区
  • 近7日
  • 近30日
  • 至今

试试用AI创作助手写篇文章吧