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


Posted in Python onOctober 24, 2019

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

# -*- coding:utf-8 -*-
#! python3
#在?C的设计中,我们需要定义一个实例属性top。三个实例方法:获取栈顶元素peek();出?Cpop();入栈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 字符串定义
Sep 25 Python
pyqt和pyside开发图形化界面
Jan 22 Python
python实现2048小游戏
Mar 30 Python
python查看zip包中文件及大小的方法
Jul 09 Python
python图像常规操作
Nov 11 Python
python+selenium实现163邮箱自动登陆的方法
Dec 31 Python
python中返回矩阵的行列方法
Apr 04 Python
python 基本数据类型占用内存空间大小的实例
Jun 12 Python
对Python3中列表乘以某一个数的示例详解
Jul 20 Python
解析python的局部变量和全局变量
Aug 15 Python
Python实现弹球小游戏
Aug 01 Python
8g内存用python读取10文件_面试题-python 如何读取一个大于 10G 的txt文件?
May 28 Python
python 队列基本定义与使用方法【初始化、赋值、判断等】
Oct 24 #Python
python单向链表的基本实现与使用方法【定义、遍历、添加、删除、查找等】
Oct 24 #Python
Windows下PyCharm2018.3.2 安装教程(图文详解)
Oct 24 #Python
python实现获取单向链表倒数第k个结点的值示例
Oct 24 #Python
python模块导入的方法
Oct 24 #Python
python读取word 中指定位置的表格及表格数据
Oct 23 #Python
win10下安装Anaconda的教程(python环境+jupyter_notebook)
Oct 23 #Python
You might like
php微信公众号开发之音乐信息
2018/10/20 PHP
laravel-admin 管理平台获取当前登陆用户信息的例子
2019/10/08 PHP
不错的asp中显示新闻的功能
2006/10/13 Javascript
老鱼 浅谈javascript面向对象编程
2010/03/04 Javascript
JS实现拖动示例代码
2013/11/01 Javascript
JavaScript实现网站访问次数统计代码
2015/08/12 Javascript
jQuery mobile 移动web(6)
2015/12/20 Javascript
js判断当前页面用什么浏览器打开的方法
2016/01/06 Javascript
Javascript的表单验证长度
2016/03/16 Javascript
JS实现的颜色实时渐变效果完整实例
2016/03/25 Javascript
JavaScript原生对象常用方法总结(推荐)
2016/05/13 Javascript
jquery实现简单Tab切换菜单效果
2020/07/17 Javascript
AngularJS实现DOM元素的显示与隐藏功能
2016/11/22 Javascript
bootstrap table操作技巧分享
2017/02/15 Javascript
3分钟快速搭建nodejs本地服务器方法运行测试html/js
2017/04/01 NodeJs
vue.js移动端app实战1:初始配置详解
2017/07/24 Javascript
Web技术实现移动监测的介绍
2017/09/18 Javascript
vue生成token并保存到本地存储中
2018/07/17 Javascript
VUE 实现element upload上传图片到阿里云
2020/08/12 Javascript
[53:49]LGD vs Fnatic 2018国际邀请赛小组赛BO2 第二场 8.18
2018/08/19 DOTA
在Python程序中进行文件读取和写入操作的教程
2015/04/28 Python
Python实现全角半角字符互转的方法
2016/11/28 Python
python队列Queue的详解
2019/05/10 Python
Python实现Restful API的例子
2019/08/31 Python
Python的互斥锁与信号量详解
2019/09/12 Python
python元组和字典的内建函数实例详解
2019/10/22 Python
jupyter notebook 多行输出实例
2020/04/09 Python
如何基于windows实现python定时爬虫
2020/05/01 Python
详解Python中@staticmethod和@classmethod区别及使用示例代码
2020/12/14 Python
英国知名美妆护肤在线商城:Zest Beauty
2018/04/24 全球购物
历史专业个人求职信范文
2013/12/07 职场文书
给老师的检讨书
2014/02/11 职场文书
机关干部四风问题自查报告及整改措施
2014/10/26 职场文书
建筑质检员岗位职责
2015/04/08 职场文书
公诉意见书范文
2015/06/05 职场文书
2015最新婚礼司仪主持词
2015/06/30 职场文书