栈(stack),有些地⽅称为堆栈,是⼀种容器,可存⼊数据元素、访问元素、删除元素,它的特点在于只能允许在容器的⼀端(称为栈顶端指标,英语:top)进⾏加⼊数据(英语:push)和输出数据(英语:pop)的运算。有了位置概念,保证任何时候可以访问、删除的元素都是此前最后存⼊的那个元素,确定了⼀种默认的访问顺序。

由于栈数据结构只允许在⼀端进⾏操作,因⽽按照后进先出(LIFO, Last In First Out)的原理运作。
栈的实现【Python】

栈结构实现

栈可以⽤顺序表实现,也可以⽤链表实现。

栈的操作

  • Stack() 创建⼀个新的空栈
  • push(item) 添加⼀个新的元素item到栈顶
  • pop() 弹出栈顶元素
  • peek()返回栈顶元素
  • is_empty() 判断栈是否为空
  • size() 返回栈的元素个数

代码实现:

class Stack(object):
 """栈"""
	def __init__(self):
		self.items = []
	def is_empty(self):
		"""判断是否为空"""
		return self.items == []
	def push(self, item):
		"""加⼊元素"""
		self.items.append(item)
	def pop(self):
		"""弹出元素"""
		return self.items.pop()
	def peek(self):
		"""返回栈顶元素"""
		return self.items[len(self.items)-1]
	def size(self):
		"""返回栈的⼤⼩"""
		return len(self.items)
		
if __name__ == "__main__":
	stack = Stack()
	stack.push("hello")
	stack.push("world")
	stack.push("itcast")
	print stack.size()
	print stack.peek()
	print stack.pop()
	print stack.pop()
	print stack.pop()

执⾏过程如下:
栈的实现【Python】

相关文章:

  • 2021-10-13
  • 2022-12-23
  • 2021-11-15
  • 2021-09-10
  • 2021-06-09
  • 2022-03-01
  • 2022-12-23
  • 2022-12-23
猜你喜欢
  • 2021-12-26
  • 2021-10-14
  • 2022-12-23
  • 2021-12-12
  • 2021-07-23
  • 2022-12-23
相关资源
相似解决方案