当前位置 主页 > 服务器问题 > Linux/apache问题 >

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

    栏目:Linux/apache问题 时间:2019-11-07 16:43

    本文实例讲述了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程序设计有所帮助。