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

python实现栈的操作入站出站查找元素等_python中实现栈的三种方法

python中实现栈的三种方法,元素,操作,列表,可以用,数据结构

python中实现栈的三种方法

易采站长站,站长之家为您整理了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()操作会消耗更多的时间

>>> 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 poped from stack

>>> print(stack.pop())

!

>>> print(stack.pop())

world

>>> print(stack.pop())

hello

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

Stack after all elements are poped

>>> print(stack)

[]

使用collections.deque实现栈

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

>>> from collections import deque

>>> 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 poped from stack

>>> print(stack.pop())

!

>>> print(stack.pop())

world

>>> print(stack.pop())

hello

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

Stack after all elements are poped

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

使用queue module实现栈

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

>>> from queue import LifoQueue

>>> stack = LifoQueue(maxsize = 3)

>>> print(stack.qsize())

0

>>> stack.put('hello')

>>> stack.put('world')

>>> stack.put('!')

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

Element poped from stack

>>> print(stack.get())

!

>>> print(stack.get())

world

>>> print(stack.get())

hello

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

Empty: True

以上就是python中实现栈的三种方法的详细内容,更多关于python 实现栈的资料请关注易采站长站其它相关文章!以上就是关于对python中实现栈的三种方法的详细介绍。欢迎大家对python中实现栈的三种方法内容提出宝贵意见

http://www.xdnf.cn/news/858817.html

相关文章:

  • 到底什么是工程师文化?
  • ARM指令教程【copy】
  • db2 事务日志使用
  • python爬虫之人人网模拟登陆示例详解
  • 【数据治理】数据治理8种方法
  • 代码阅读工具:Source Navigator和Source Insight
  • python入门教程(非常详细),从零基础入门到精通,看完这一篇就够了
  • 电脑任务栏没反应但是桌面有反应?5招解决!
  • [macos] 通过usb共享网络给iphone
  • 23种绳结的绑法,受用无穷,值得收藏!
  • 【单片机毕业设计】【mcuclub-dz-205】基于物联网技术的智能家居自动控制系统设计
  • Java基础笔记(初学者适用)
  • php的password_verify 和 password_hash密码验证
  • 【终终极版】linux(Ubuntu)下wineQQ的安装办法
  • 红旗linux如何开远程桌面,配置VNC服务实现红旗Linux远程桌面访问
  • 【微信小程序-0基础入门】项目发布完整流程_小程序发布流程怎么弄(1)
  • MySQL 安装与配置指南
  • 什么是物联网监控平台?部署物联网平台有什么作用?
  • Java的开发工具有哪些?这十款工具大厂都在用!
  • Linux下GCC的安装
  • kali linux渗透测试之漏洞扫描
  • 网络安全加固的五大手段!
  • MATLAB群智能开源第十九期-爬虫搜索算法
  • 微信查券返利机器人设置指南,轻松实现优惠券自动查询
  • 【转载】FileUpload控件如何实现上传和文件属性获取
  • GPS巡检管理系统新思路-灵活、快捷、智能巡检系统解决方案_设备智能巡检系统,设备巡检系统,智能巡更管理系统,森林防护AI智能识别巡检系统,智慧工地智能巡检系统,数字化巡检系统,智能巡检管理系统
  • 搭建自己的个人服务器(网络配置篇)
  • Keil的软件仿真和硬件仿真
  • 写字楼管理系统软件哪款好
  • 五款上网行为管理软件,5款常用的电脑上网行为管理软件