博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
python数据结构与算法(10)
阅读量:6186 次
发布时间:2019-06-21

本文共 1517 字,大约阅读时间需要 5 分钟。

栈(stack),有些地⽅称为堆栈,是⼀种容器,可存⼊数据元素、访问元 素、删除元素,它的特点在于只能允许在容器的⼀端(称为栈顶端指标,英 语:top)进⾏加⼊数据(英语:push)和输出数据(英语:pop)的运算。 没有了位置概念,保证任何时候可以访问、删除的元素都是此前最后存⼊的 那个元素,确定了⼀种默认的访问顺序。
由于栈数据结构只允许在⼀端进⾏操作,因⽽按照后进先出(LIFO, Last In First Out)的原理运作。
python数据结构与算法(10)
栈结构实现
栈可以⽤顺序表实现,也可以⽤链表实现。
栈的操作
Stack() 创建⼀个新的空栈 push(item) 添加⼀个新的元素item到栈顶 pop() 弹出栈顶元素 peek() 返回栈顶元素 is_empty() 判断栈是否为空 size() 返回栈的元素个数

class   Stack(object):              """栈"""             def __init__(self):                                 self.items  =   []                def is_empty(self):                             """判断是否为空"""                                return  self.items  ==  []                def push(self,  item):                              """加⼊元素"""                              self.items.append(item)                def pop(self):                              """弹出元素"""                              return  self.items.pop()                def peek(self):                             """返回栈顶元素"""                                return  self.items[len(self.items)-1]        def size(self):                             """返回栈的⼤⼩"""                                return  len(self.items)if  __name__    ==  "__main__":             stack   =   Stack()             stack.push("hello")             stack.push("world")             stack.push("itcast")                print   stack.size()                print   stack.peek()                print   stack.pop()             print   stack.pop()             print   stack.pop()

执⾏过程如下:

python数据结构与算法(10)

转载于:https://blog.51cto.com/13517854/2323072

你可能感兴趣的文章
我的友情链接
查看>>
虚拟机虚拟网卡作用
查看>>
Java各种修饰限定符的权限范围
查看>>
关于在Word、Excel、Outlook等ofifce软件中打开超链接时提示:由于本机限制,请与管理员联系。的解决方法...
查看>>
shell十三问-13) for what? while 与 until 差在哪
查看>>
Hibernate笔记——10.继承映射
查看>>
我的友情链接
查看>>
extmail邮件系统 网页加载特别慢,加载超时 解决方法
查看>>
修改linux系统用户最大线程数限制
查看>>
虚拟网卡使用笔记
查看>>
Selenese 命令清单 - store相关命令
查看>>
Java运行时获取当前运行代码类名、方法名
查看>>
Eclipse快捷键
查看>>
【C语言】求 a+aa+aaa+aaaa+aaaaa
查看>>
自己遇到的mysql主从同步错误及解决
查看>>
rsync应用
查看>>
sccm 1511Windows PE 初始化失败,错误代码为 0x80220014
查看>>
MAC OS 搭建PHP开发环境
查看>>
LVM 详解(1)
查看>>
【C语言】注释不可以嵌套使用的举例
查看>>