无名阁,只为技术而生。流水不争先,争的是滔滔不绝。

(python stack) 详解Python 栈(后进先出) Python栈(Stack)简介 全网首发(图文详解1)

前沿技术 Micheal 8个月前 (05-27) 122次浏览 已收录 扫描二维码

(python stack) 详解Python 栈(后进先出)

Python栈(Stack)是一种线性数据结构,它遵循特定的顺序进行访问和操作数据。它遵循LIFO(后进先出)数据结构。在栈中,数据项仅从列表的一端添加和删除,这端通常被称为”顶”。栈底是不变的,因此,数据项一路向顶部添加,新的数据项被添加时,旧的数据项被推倒了下来。

使用Python内置的列表数据结构可以非常容易地实现栈。列表有各种内置方法,如 append() 和 pop(),这些可以被用来模拟栈的 push 和 pop 操作。

以下是一个栈的使用示例:

# 创建一个空栈
stack = []

# 向栈中添加元素(push操作)
stack.append('a')
stack.append('b')
stack.append('c')

print('初始栈:')
print(stack)

# 从栈中移除元素(pop操作),应该是后进先出
print('\n元素顺序弹出:')
print(stack.pop())
print(stack.pop())
print(stack.pop())

print('\n栈在所有元素被弹出后:')
print(stack)

执行上述代码,你会得到以下输出:

初始栈:
['a', 'b', 'c']

元素顺序弹出:
'c'
'b'
'a'

栈在所有元素被弹出后:
[]

上边是Python自带的列表方法实现的简单栈,如果你希望使用专门的栈数据结构的话,你可以使用Python的内置模块 collections 下的 deque 类。代码如下:

from collections import deque

# 初始化一个栈
stack = deque()

# 入栈操作
stack.append('a')
stack.append('b')
stack.append('c')

print('初始栈:')
print(stack)

# 出栈操作
print('\n元素popped from stack:')
print(stack.pop())
print(stack.pop())
print(stack.pop())

print('\n栈在所有元素被弹出后:')
print(stack)

运行结果和先前的代码片段相同。
(.iloc) Pandas loc、iloc用法详解 Pandas.loc和iloc索引方式 全网首发(图文详解1)
(python) Python assert断言关键字的作用与用法 Python assert 语法简介 全网首发(图文详解1)

喜欢 (0)
[]
分享 (0)
关于作者:
流水不争先,争的是滔滔不绝