zoukankan      html  css  js  c++  java
  • python栈

    #在桟的设计中,我们需要定义一个实例属性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)
  • 相关阅读:
    Code Review(代码的自我评审)
    在ANDROID STUDIO环境下使用Espresso 测试框架进行UI测试
    第一个迭代任务——倒计时
    Scrum的3种角色划分——倒计时
    需求分析(WBS图)
    countdown(计时器)
    Countdown(计时器)
    团队模式选择
    软件开发流程
    软件团队的模式
  • 原文地址:https://www.cnblogs.com/kunpengv5/p/8c28d7546cf541ef7d251339ce23fc2a.html
Copyright © 2011-2022 走看看