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
  • asp之家 网络编程 m.aspxhome.com