python

超轻量级php框架startmvc

python栈的基本定义与使用方法示例【初始化、赋值、入栈、出栈等】

更新时间:2020-08-04 10:18:01 作者:startmvc
本文实例讲述了python栈的基本定义与使用方法。分享给大家供大家参考,具体如下:#-*-codin

本文实例讲述了python栈的基本定义与使用方法。分享给大家供大家参考,具体如下:


# -*- coding:utf-8 -*-
#! python3
#在桟的设计中,我们需要定义一个实例属性top。三个实例方法:获取栈顶元素peek();出桟pop();入栈push()
#栈的效果:先进后出
class Node(object): ##节点,包括两个属性,一个是节点的值,一个是节点的下一个指向
 def __init__(self,value):
 self.value = value #赋值给节点
 self.next = None #节点的下一个指向
class stack(object):
 def __init__(self):
 self.top = None #创建栈,赋予top栈顶属性,top初始为空
 def peek(self): #获取栈顶的元素,返回对应的值
 if self.top!= None: #如果栈顶不为空,也就是说栈里有数据
 return self.top.value #那就直接返回栈顶的值
 else:
 return None #如果栈里无数据,则返回None
 def push(self,node): #添加元素到栈(参数包括self和节点的value,node)
 if node != None: #如果加入的节点,不为空
 packNode = Node(node) #实例化Node类
 packNode.next = self.top #将新增的节点的指向赋值为栈顶的指向
 self.top = packNode #将栈顶的节点,赋值为新增节点
 return packNode.value #返回节点的值
 else:
 return None #返回None
 def pop(self): #出栈
 if self.top == None: #如果栈是空的
 return None #返回None
 else:
 tmp = self.top.value #将栈顶的值传给tmp
 self.top = self.top.next #将栈顶指向变为目前栈顶的下一个节点
 return tmp #返回出栈的节点的值
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 基本定义 使用方法 初始化 赋值 入栈 出栈