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

本文实例讲述了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相关内容感兴趣的读者可查看本站专题:《Python数据结构与算法教程》、《Python加密解密算法与技巧总结》、《Python编码操作技巧总结》、《Python函数使用技巧总结》、《Python字符串操作技巧汇总》及《Python入门与进阶经典教程》

希望本文所述对大家Python程序设计有所帮助。

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

本文地址: http://www.cppcns.com/jiaoben/python/281842.html

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值