网站首页 > 教程文章 正文
栈是一种先进后出的数据结构。
栈顶,栈底
- 从栈顶向栈底添加元素,从栈顶取元素
应用:每个 web 浏览器都有一个返回按钮。当你浏览网页时,这些网页被放置在一个栈中(实际是网页的网址)。我们正在查看的网页在顶部,第一个查看的网页在底部。如果按 返回 按钮,将按相反的顺序浏览之前的页面。
接下来,我们通过 Python 代码实现一个栈:
- Stack() 创建一个空的新栈。 它不需要参数,并返回一个空栈。
- push(item) 将一个新项添加到栈的顶部。它需要 item 做参数并不返回任何内容。
- pop() 从栈中删除顶部项。它不需要参数并返回 item。栈被修改。
- peek() 从栈返回顶部项,但不会删除它。不需要参数。 不修改栈。
- isEmpty() 测试栈是否为空。不需要参数,并返回布尔值。
- size() 返回栈中的 item 数量。不需要参数,并返回一个整数。
class Stack:
def __init__(self):
self.items = [] # 构建一个空栈
def push(self, item): # 从栈顶添加到栈底
self.items.append(item)
def pop(self): # 从栈顶向栈底取元素
return self.items.pop()
def peek(self): # 返回栈顶元素下标
return len(self.items) - 1
def isEmpty(self):
return self.items == []
def size(self):
return len(self.items)
if __name__ == '__main__':
s = Stack()
print(s.isEmpty()) # True
s.push(1)
s.push(2)
s.push(3)
print(s.isEmpty()) # False
print(s.peek()) # 2
print(s.size()) # 3
print(s.pop()) # 3
print(s.pop()) # 2
print(s.pop()) # 1
- 上一篇: 栈c++.(斩赤红之瞳)
- 下一篇: 稳了,一文学会栈和队列!(栈和队列的基本概念)
猜你喜欢
- 2025-04-07 数据结构学习(八)栈和队列案例分析
- 2025-04-07 栈的顺序存储结构(栈的顺序存储结构定义及操作的实现)
- 2025-04-07 数据结构——第3章-栈和队列(栈和队列这两种数据结构各自有什么特点)
- 2025-04-07 想做外挂?先把汇编学好吧(汇编编程软件)
- 2025-04-07 Python常用算法学习(4) 数据结构(原理+代码)-最全总结
- 2025-04-07 Linux 多线程全面解析(linux多线程编程详解)
- 2025-04-07 栈是什么?栈有什么作用(栈是什么意思啊)
- 2025-04-07 手写“栈”数据结构(数据结构栈的实现代码)
- 2025-04-07 C/C++|头文件、源文件分开写的源起及作用
- 2025-04-07 实模式下CPU如何获取数据及指令(实模式下,cpu要执行的下一条指令的逻辑地址)
- 最近发表
- 标签列表
-
- location.href (44)
- document.ready (36)
- git checkout -b (34)
- 跃点数 (35)
- 阿里云镜像地址 (33)
- qt qmessagebox (36)
- md5 sha1 (32)
- mybatis plus page (35)
- semaphore 使用详解 (32)
- update from 语句 (32)
- vue @scroll (38)
- 堆栈区别 (33)
- 在线子域名爆破 (32)
- 什么是容器 (33)
- sha1 md5 (33)
- navicat导出数据 (34)
- 阿里云acp考试 (33)
- 阿里云 nacos (34)
- redhat官网下载镜像 (36)
- srs服务器 (33)
- pico开发者 (33)
- https的端口号 (34)
- vscode更改主题 (35)
- 阿里云资源池 (34)
- os.path.join (33)