本文实例讲述了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程序设计有所帮助。
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件!
如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
白云城资源网 Copyright www.dyhadc.com
暂无“python栈的基本定义与使用方法示例【初始化、赋值、入栈、出栈等】”评论...
更新日志
2024年10月07日
2024年10月07日
- 群星《前途海量 电影原声专辑》[FLAC/分轨][227.78MB]
- 张信哲.1992-知道新曲与精丫巨石】【WAV+CUE】
- 王翠玲.1995-ANGEL【新艺宝】【WAV+CUE】
- 景冈山.1996-我的眼里只有你【大地唱片】【WAV+CUE】
- 群星《八戒 电影原声带》[320K/MP3][188.97MB]
- 群星《我的阿勒泰 影视原声带》[320K/MP3][139.47MB]
- 纪钧瀚《胎教古典音乐 钢琴与大提琴的沉浸时光》[320K/MP3][148.91MB]
- 刘雅丽.2001-丽花皇后·EMI精选王【EMI百代】【FLAC分轨】
- 齐秦.1994-黄金十年1981-1990CHINA.TOUR.LIVE精丫上华】【WAV+CUE】
- 群星.2008-本色·百代音乐人创作专辑【EMI百代】【WAV+CUE】
- 群星.2001-同步过冬AVCD【环球】【WAV+CUE】
- 群星.2020-同步过冬2020冀待晴空【环球】【WAV+CUE】
- 沈雁.1986-四季(2012梦田复刻版)【白云唱片】【WAV+CUE】
- 纪钧瀚《胎教古典音乐 钢琴与大提琴的沉浸时光》[FLAC/分轨][257.88MB]
- 《国语老歌 怀旧篇 3CD》[WAV/分轨][1.6GB]