栈是链表的一种应用,栈的数据结构类型就是链表。
特点:先进后出。就像一个瓶子,瓶底的是先进去,最后出来。
那么对栈的响应操作就没有那么多了,只有入栈,出栈,遍历,计算长度。
下面通过代码来实现:
#节点实现
class Node(object):
def __init__(self,i):
self.val = i
self.next = None
#栈实现
class stack(object):
def __init__(self,node):
self.head = node
def append_s(self,i):
node = Node(i)
cur = self.head
if cur.next == None:
cur.next = node
return
while cur.next != None:
cur = cur.next
cur.next = node
#弹栈
def pop_s(self):
cur = self.head
pre = cur
if cur.next == None:
self.head = None
return
while cur.next != None:
pre = cur
cur = cur.next
pre.next = None
#计算栈中的元素长度
def len_s(self):
count = 0
cur = self.head
while cur != None:
count += 1
cur = cur.next
return count
#对栈进行遍历
def travel_s(self):
cur = self.head
while cur != None:
print(cur.val)
cur = cur.next
node = Node(1)
s = stack(node)
print(s.len_s())
s.travel_s()
s.append_s(2)
print(s.len_s())
s.travel_s()
运行结果:
1
1
2
1
2
附上一题剑指offer的题:
使用两个栈实现一个队列的功能,对队列进行添加和删除元素。
(这里的栈是直接使用列表来代替,不是狭义的栈)
#队列实现
class Queue(object):
def __init__(self):
self.A = []
self.B = []
def appendq(self,i):
self.A.append(i) #尾插
self.B.insert(0,i) #头插
def deleteq(self,i):
if len(self.A) == 0:
return -1
self.A.pop(0)
return self.B.pop()
def trave(self):
for i in self.A:
print(i,end='\t')
print()
queue = Queue()
queue.appendq(3)
queue.trave()
queue.appendq(5)
queue.trave()
dq = queue.deleteq(3)
queue.trave()
运行结果:
3
3 5
5