定义

栈(stack),有些地方称为堆栈,是一种容器,可存入数据元素,访问元素,删除元素,它的特点在于只允许在容器的一端(称为栈顶端指标,英语:top)进行加入数据(英语:push)和输出数据(英语:pop)的运算。没有了位置的概念,保证任何时候可以访问删除的元素都是此前最后存入的那个元素,确定了一种默认的访问顺序。
由于栈数据结构只允许在一端进行操作,因而按照后进先出(LIFO,Last in First Out)的原理运作
image.png

栈结构实现

  1. Stack()创建一个空栈
  2. push()添加一个新的元素item到栈顶
  3. pop()弹出栈顶元素
  4. peek()返回栈顶元素
  5. is_empty()判断栈是否为空
  6. size()返回栈的元素个数

代码实现

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
#!/usr/bin/env python
# -*- coding: UTF-8 -*-
"""
@Project :python算法
@File :11栈.py
@IDE :PyCharm
@Author :咋
@Date :2023/1/3 17:00
"""
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("bjsxt")
print(stack.size())
print(stack.peek())
print(stack.pop())
print(stack.pop())
print(stack.pop())