当前位置: 首页 > news >正文

python中实现栈的三种方法

栈是一种线性数据结构,用先进后出或者是后进先出的方式存储数据,栈中数据的插入删除操作都是在栈顶端进行,常见栈的函数操作包括

  • empty() – 返回栈是否为空 – Time Complexity : O(1)
  • size() – 返回栈的长度 – Time Complexity : O(1)
  • top() – 查看栈顶元素 – Time Complexity : O(1)
  • push(g) – 向栈顶添加元素 – Time Complexity : O(1)
  • pop() – 删除栈顶元素 – Time Complexity : O(1)

python中栈可以用以下三种方法实现:

1)list

2)collections.deque

3)queue.LifoQueue

使用列表实现栈

python的内置数据结构list可以用来实现栈,用append()向栈顶添加元素, pop() 可以以后进先出的顺序删除元素

但是列表本身有一些缺点,主要问题就是当列表不断扩大的时候会遇到速度瓶颈.列表是动态数组,因此往其中添加新元素而没有空间保存新的元素时,它会自动重新分配内存块,并将原来的内存中的值复制到新的内存块中.这就导致了一些append()操作会消耗更多的时间

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

29

>>> stack=[]

>>>#append() fuction to push

...#element in list

...

>>> stack.append('hello')

>>> stack.append('world')

>>> stack.append('!')

>>>print('Initial stack')

Initial stack

>>>print(stack)

['hello','world','!']

>>>#pop() function to pop element

...#from stack in LIFO order

...

>>>print('\nElement poped from stack')

Element popedfromstack

>>>print(stack.pop())

!

>>>print(stack.pop())

world

>>>print(stack.pop())

hello

>>>print('\nStack after all elements are poped')

Stack afterallelements are poped

>>>print(stack)

[]

使用collections.deque实现栈

python中栈也可以用deque类实现,当我们想要在实现在容器两端更快速地进行append和pop操作时,deque比列表更合适.deque可以提供O(1)时间的append和pop操作,而列表则需要O(n)时间.

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

20

21

22

23

24

25

26

27

28

>>>fromcollectionsimportdeque

>>> stack=deque()

>>># append() fuction to push

...#element in list

...

>>> stack.append('hello')

>>> stack.append('world')

>>> stack.append('!')

>>>print('Initial stack')

Initial stack

>>>print(stack)

deque(['hello','world','!'])

>>>#pop() function to pop element

...#from stack in LIFO order

...

>>>print('\nElement poped from stack')

Element popedfromstack

>>>print(stack.pop())

!

>>>print(stack.pop())

world

>>>print(stack.pop())

hello

>>>print('\nStack after all elements are poped')

Stack afterallelements are poped

>>>print(stack)deque([])

使用queue module实现栈

Queue模块有LIFO queue,也就是栈结构.用put()和get()操作从Queue中添加和获得数据

1

2

3

4

5

6

7

8

9

10

11

12

13

14

15

16

17

18

19

>>>fromqueueimportLifoQueue

>>> stack=LifoQueue(maxsize=3)

>>>print(stack.qsize())

0

>>> stack.put('hello')

>>> stack.put('world')

>>> stack.put('!')

>>>print('\nElement poped from stack')

Element popedfromstack

>>>print(stack.get())

!

>>>print(stack.get())

world

>>>print(stack.get())

hello

>>>print('\nEmpty:', stack.empty())

Empty:True

以上就是python中实现栈的三种方法的详细内容

http://www.jsqmd.com/news/709014/

相关文章:

  • Cursor Pro终极破解指南:3步实现永久免费AI编程体验
  • 【Hot 100 刷题计划】 LeetCode 2. 两数相加 | C++ 分支迭代法
  • 2026展厅展馆设计施工:博物馆校史馆企业展厅专业服务商推荐 - 深度智识库
  • Pixelle-Video深度解析:基于ComfyUI架构的AI短视频引擎架构设计与最佳实践
  • 扩散变换器动态补丁调度技术DDiT解析
  • Stable Diffusion Forge终极部署方案:打造高性能AI创作环境的完整指南
  • 如何在Windows上免费实现AirPlay 2投屏:打破苹果生态壁垒的完整指南
  • 告别本地跑模型!用PyCharm专业版SSH直连AutoDL服务器,保姆级配置避坑指南
  • 免费开源屏幕标注神器ppInk:让数字沟通更直观高效的终极指南
  • S32K146 ADC实战:从EB Tresos配置到数据读取,一个真实电池电压采集项目的完整流程
  • 用OpenCV的HOG+SVM手把手教你做个简易行人检测器(附完整代码)
  • 别再死记硬背公式了!用Multisim仿真带你玩转RC文氏桥振荡器
  • .NET 代码规范、CodeReview、 重构
  • 2026年昆明代理记账与工商变更一站式企业财税合规服务深度横评 - 企业名录优选推荐
  • 个人飞行器-第五周制作步骤
  • 跨越生态鸿沟:APK-Installer如何重塑Windows与Android的边界
  • 开题报告被反复打回?一怒之下试了7款AI开题报告工具,这款居然帮你一次通关 - 逢君学术-AI论文写作
  • 你的GRE隧道稳吗?H3C设备上配置Keepalive与密钥验证的避坑指南
  • Go语言构建高可用分布式任务调度框架:从Cron到Copaw的实践
  • 小爱音箱自定义固件终极教程:三步打造你的专属智能语音助手
  • 边缘AI抓取机器人:zeptoclaw项目解析与轻量级视觉抓取实践
  • 2026年5月百达翡丽维修中心最新通知:全国维修网点地址更新,百达翡丽统一服务热线400-1063365正式启用 - 速递信息
  • 2026年4月云南酒席棚/活动雨棚/膜结构景观膜/张拉膜结构车棚/膜结构遮阳棚厂家解析 - 2026年企业推荐榜
  • 基于Tesseract的轻量级HTTP OCR服务部署与实战优化指南
  • 4步掌握Arduino-ESP32开源项目:从嵌入式新手到物联网专家完全指南
  • 阿拉伯语RAG评估框架构建与多方言处理技术
  • 互联网大厂Java求职面试:从Spring Boot到微服务的技术深度探讨
  • 黄气重+痘印深?学生党冲这款常天然精华,温和美白,早晚都能用 - 资讯焦点
  • 炸了!Claude Code 移除 Pro 用户!!
  • AI智能体安全守护:agent-guardian的内存限制与行为监控实战