python 栈
2018-06-26 本文已影响0人
luoganttcc
#!/usr/bin/python
# -*- coding: utf-8 -*-
#给一个点,我们能够根据这个点知道一些内容
class Node(object):
def __init__(self,val=None,next=None): #定位的点的值和一个指向
self.val=val #指向元素的值,原队列第二元素
self.next=next #指向的指针
'''
class Node:
def __init__(self,value=None,left=None,right=None):
self.value=value
self.left=left #左子树
self.right=right #右子树
'''
class stack(object):
def __init__(self):
self.top=None #初始化最开始的位置
def peek(self): #获取栈顶的元素
if self.top!=None: #如果栈顶不为空
return self.top.val #返回栈顶元素的值
else:
return None
def push(self,n):#添加到栈中
n=Node(n) #实例化节点
n.next=self.top #顶端元素传值给一个指针
self.top=n #
return n.val
def pop(self): #退出栈
if self.top == None:
return None
else:
tmp=self.top.val
self.top=self.top.next #下移一位,进行
return tmp
if __name__=="__main__":
s=stack()
s.push(1)
s.push(2)
s.push(3)
print (s.pop())
print (s.pop())
print (s.pop())
3
2
1