写在前面
在上一节part1我们熟悉数组和链表,本节继续对其他常见数据结构进行总结。我们的目的是快速了解他们,对于它们涉及到的复杂的数据结构和算法,在这里并不全部展开,留在后期详述。
1. 栈
栈(stack)也是一种线性结构,与数组不同的是,栈限定了只能在线性表的一端,例如尾部进入插入或者删除操作(只允许头部操作类似)。
栈类似于把车开入了一个死胡同,只剩下一端,只能从这个入口进入或者出去,这个进入称之为入栈操作(push),退出则称之为出栈操作(pop)。最后在这个死胡同里,车子只能从最后进入的那位开始依次往后倒车开出去,这就是连续出栈操作,直到栈为空。在出栈过程中,最先进入的最后出去,这称之为后进先出(Last In First Out,LIFO)。
在数据结构中,栈中一般存储同类型元素,当然也允许存储不同类型元素,例如动态语言中实现的栈。栈的操作如下图所示(图片来自tutorial point):
1.1 栈的实现
Python中没有显式提供栈结构,不过list结构可以当做栈来使用。
入栈和出栈操作实现为:
stack = ['a']
stack.append('b') # 入栈操作
stack.append('c')
print(stack) # ['a', 'b', 'c']
content = stack.pop() # 出栈操作
print(content) # 'c'
print(stack) # ['a', 'b']
下面我们也对list进行一个封装,自己动手实现一个简单的栈。
class Stack(object):
"""
栈
"""
def __init__(self):
self.data = []
def __str__(self):
output_str = "stack["
for x in self.data:
output_str += str(x)+","
output_str += "]"
return output_str
def is_empty(self):
return not self.data
def push(self, element):
self.data.append(element)
def pop(self):
return self.data.pop()
def top(self):
if self.data:
return