python栈的基本定义与使用方法示例【初始化、赋值、入栈、出栈等】
本文实例讲述了python栈的基本定义与使用方法。分享给大家供大家参考,具体如下:
#-*-coding:utf-8-*- #!python3 #在桟的设计中,我们需要定义一个实例属性top。三个实例方法:获取栈顶元素peek();出桟pop();入栈push() #栈的效果:先进后出 classNode(object):##节点,包括两个属性,一个是节点的值,一个是节点的下一个指向 def__init__(self,value): self.value=value#赋值给节点 self.next=None#节点的下一个指向 classstack(object): def__init__(self): self.top=None#创建栈,赋予top栈顶属性,top初始为空 defpeek(self):#获取栈顶的元素,返回对应的值 ifself.top!=None:#如果栈顶不为空,也就是说栈里有数据 returnself.top.value#那就直接返回栈顶的值 else: returnNone#如果栈里无数据,则返回None defpush(self,node):#添加元素到栈(参数包括self和节点的value,node) ifnode!=None:#如果加入的节点,不为空 packNode=Node(node)#实例化Node类 packNode.next=self.top#将新增的节点的指向赋值为栈顶的指向 self.top=packNode#将栈顶的节点,赋值为新增节点 returnpackNode.value#返回节点的值 else: returnNone#返回None defpop(self):#出栈 ifself.top==None:#如果栈是空的 returnNone#返回None else: tmp=self.top.value#将栈顶的值传给tmp self.top=self.top.next#将栈顶指向变为目前栈顶的下一个节点 returntmp#返回出栈的节点的值 s=stack() a=Node(1) print(s.push(a).value) print(s.push(2)) print(s.push(3)) print(s.peek()) print(s.push(4)) print(s.pop()) print(s.pop()) print(s.pop()) print(s.pop().value)
运行结果:
1
2
3
3
4
4
3
2
1
更多关于Python相关内容感兴趣的读者可查看本站专题:《Python数据结构与算法教程》、《Python加密解密算法与技巧总结》、《Python编码操作技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》
希望本文所述对大家Python程序设计有所帮助。