Python栈的实现方法示例【列表、单链表】
作者:授我以驴 时间:2023-07-20 15:51:42
本文实例讲述了Python栈的实现方法。分享给大家供大家参考,具体如下:
Python实现栈
栈的数组实现:利用python列表方法
代码如下:
# 列表实现栈,利用python列表方法
class listStack(object):
def __init__(self):
self.items = []
def is_empty(self):
return self.items == 0
def size(self):
return len(self.items)
def top(self):
return self.items[len(self.items)-1]
def push(self, value):
return self.items.append(value)
def pop(self):
return self.items.pop()
if __name__ =="__main__":
stack = listStack()
stack.push("welcome")
stack.push("www")
stack.push("aspxhome")
stack.push("net")
print "栈的长度:", stack.size()
print "\n".join(['%s:%s' % item for item in stack.__dict__.items()]) #打印栈stack所有元素
print "出栈:",stack.pop()
print "出栈:",stack.pop()
print "出栈:",stack.pop()
运行结果:
栈的长度: 4
items:['welcome', 'www', 'aspxhome', 'net']
出栈: net
出栈: aspxhome
出栈: www
栈的链表实现:
栈的链表实现中,压栈(push)类似于在单链表中表头添加节点;出栈(pop)类似于链表中表头删除节点并返回对应节点值;栈顶元素(top)就是获取链表中的第一个元素
链表节点的定义直接嵌套在链表栈类中
代码如下:
# 链表实现栈
class linkedStack(object):
class Node(object):
def __init__(self, value=None, next=None):
self.value = value
self.next = next
def __init__(self):
self.top = None
self.length = 0
def is_empty(self):
return self.length == 0
def size(self):
return self.length
# 获取栈顶元素
def get(self):
if self.is_empty():
raise Exception("Stack is empty!")
return self.top.value
# 压栈
def push(self, value):
node = self.Node(value)
old_top = self.top
self.top = node
node.next = old_top
self.length += 1
# 出栈
def pop(self):
if self.length == 0:
raise Exception("Stack is empty!")
item = self.top.value
curnode = self.top.next
self.top.next = self.top
self.top = curnode
self.length -= 1
return item
if __name__ =="__main__":
stack = linkedStack()
stack.push("welcome")
stack.push("www")
stack.push("aspxhome")
stack.push("net")
print "栈的长度:", stack.size()
print "出栈:",stack.pop()
print "出栈:",stack.pop()
print "出栈:",stack.pop()
print "出栈:",stack.pop()
运行结果:
栈的长度: 4
出栈: net
出栈: aspxhome
出栈: www
出栈: welcome
希望本文所述对大家Python程序设计有所帮助。
来源:https://blog.csdn.net/one_Salted_FishGG/article/details/99878420
标签:Python,栈,列表,单链表
0
投稿
猜你喜欢
根据表名和索引获取需要的列名的存储过程
2011-09-30 11:54:42
python调用摄像头的示例代码
2021-10-11 02:18:09
Python Django框架设计模式详解
2021-01-16 12:52:40
以PHP代码为实例详解RabbitMQ消息队列中间件的6种模式
2023-06-08 12:15:53
Python 制作自动化翻译工具
2022-08-17 05:34:50
python自动化测试之从命令行运行测试用例with verbosity
2021-09-20 07:32:16
python深度学习tensorflow安装调试教程
2021-06-28 23:03:51
Python实现邮件发送功能的方法详解
2021-02-02 10:34:58
TypeScript中命名空间与模块化详情
2024-04-25 13:11:23
asp MYSQL出现问号乱码的解决方法
2011-04-15 11:13:00
ASP+MSSQL2000 数据库被批量注入后的解决方法第1/2页
2011-04-06 10:50:00
windows 64位下mysql8.0.25安装配置教程(最详细!)
2024-01-22 17:36:27
Django使用mysqlclient服务连接并写入数据库的操作过程
2024-01-27 14:55:39
几个图片按比例缩放的代码
2008-02-13 08:51:00
oracle修改scott密码与解锁的方法详解
2024-01-19 19:10:40
解决Django一个表单对应多个按钮的问题
2021-07-15 15:34:55
vue项目页面的打印和下载PDF加loading效果的实现(加水印)
2024-04-30 10:29:39
SQL Server数据库连接查询和子查询实战案例
2024-01-15 02:44:21
JavaScript如何动态监听DOM元素高度详解
2024-05-22 10:32:00
浅谈MySQL之select优化方案
2024-01-27 03:32:38