栈(stack)

栈又称之为堆栈是一个特殊的有序表,其插入和删除操作都在栈顶进行操作,并且按照先进后出,后进先出的规则进行运作。
如下图所示
例如枪的弹匣,第一颗放进弹匣的子弹反而在发射出去的时候是最后一个,而最后放入弹匣的一颗子弹在打出去的时候是第一颗发射出去的。
栈的接口
如果你创建了一个栈,那么那么应该具有以下接口来进行对栈的操作
| 接口 | 描述 |
|---|---|
| push() | 入栈 |
| pop() | 出栈 |
| isEmpty() | 判断是否为空栈 |
| length() | 获取栈的长度 |
| getTop() | 取栈顶的元素,元素不出栈 |
知道栈需要上述的接口后,那么在Python中,列表就类似是一个栈,提供接口如下:
| 操作 | 描述 |
|---|---|
| s = [] | 创建一个栈 |
| s.append(x) | 往栈内添加一个元素 |
| s.pop() | 在栈内删除一个元素 |
| not s | 判断是否为空栈 |
| len(s) | 获取栈内元素的数量 |
| s[-1] | 获取栈顶的元素 |
Python中的栈接口使用实例:
# 创建一个栈 In [1]: s = [] # 往栈内添加一个元素 In [2]: s.append(1) In [3]: s Out[3]: [1] # 删除栈内的一个元素 In [4]: s.pop() Out[4]: 1 In [5]: s Out[5]: [] # 判断栈是否为空 In [6]: not s Out[6]: True In [7]: s.append(1) In [8]: not s Out[8]: False # 获取栈内元素的数量 In [9]: len(s) Out[9]: 1 In [10]: s.append(2) In [11]: s.append(3) # 取栈顶的元素 In [12]: s[-1] Out[12]: 3
一大波实例
在了解栈的基本概念之后,让我们再来看几个实例,以便于理解栈。
括号匹配
题目
假如表达式中允许包含三中括号()、[]、{},其嵌套顺序是任意的,例如:
正确的格式
{()[()]},[{({})}]
错误的格式
[(]),[()),(()}
编写一个函数,判断一个表达式字符串,括号匹配是否正确
思路
解决代码
建议在pycharm中打断点,以便于更好的理解
#!/use/bin/env python
# _*_ coding:utf-8 _*_
LEFT = {'(', '[', '{'} # 左括号
RIGHT = {')', ']', '}'} # 右括号
def match(expr):
"""
:param expr: 传过来的字符串
:return: 返回是否是正确的
"""
stack = [] # 创建一个栈
for brackets in expr: # 迭代传过来的所有字符串
if brackets in LEFT: # 如果当前字符在左括号内
stack.append(brackets) # 把当前左括号入栈
elif brackets in RIGHT: # 如果是右括号
if not stack or not 1 <= ord(brackets) - ord(stack[-1]) <= 2:
# 如果当前栈为空,()]
# 如果右括号减去左括号的值不是小于等于2大于等于1
return False # 返回False
stack.pop() # 删除左括号
return not stack # 如果栈内没有值则返回True,否则返回False
result = match('[(){()}]')
print(result)
迷宫问题
题目
用一个二维数组表示一个简单的迷宫,用0表示通路,用1表示阻断,老鼠在每个点上可以移动相邻的东南西北四个点,设计一个算法,模拟老鼠走迷宫,找到从入口到出口的一条路径。
如图所示
出去的正确线路如图中的红线所示
思路
解决代码
#!/use/bin/env python # _*_ coding:utf-8 _*_ def initMaze(): """ :return: 初始化迷宫 """ maze = [[0] * 7 for _ in range(5 + 2)] # 用列表解析创建一个7*7的二维数组,为了确保迷宫四周都是墙 walls = [ # 记录了墙的位置 (1, 3), (2, 1), (2, 5), (3, 3), (3, 4), (4, 2), # (4, 3), # 如果把(4, 3)点也设置为墙,那么整个迷宫是走不出去的,所以会返回一个空列表 (5, 4) ] for i in range(7): # 把迷宫的四周设置成墙 maze[i][0] = maze[i][-1] = 1 maze[0][i] = maze[-1][i] = 1 for i, j in walls: # 把所有墙的点设置为1 maze[i][j] = 1 return maze """ [1, 1, 1, 1, 1, 1, 1] [1, 0, 0, 1, 0, 0, 1] [1, 1, 0, 0, 0, 1, 1] [1, 0, 0, 1, 1, 0, 1] [1, 0, 1, 0, 0, 0, 1] [1, 0, 0, 0, 1, 0, 1] [1, 1, 1, 1, 1, 1, 1] """ def path(maze, start, end): """ :param maze: 迷宫 :param start: 起始点 :param end: 结束点 :return: 行走的每个点 """ i, j = start # 分解起始点的坐标 ei, ej = end # 分解结束点的左边 stack = [(i, j)] # 创建一个栈,并让老鼠站到起始点的位置 maze[i][j] = 1 # 走过的路置为1 while stack: # 栈不为空的时候继续走,否则退出 i, j = stack[-1] # 获取当前老鼠所站的位置点 if (i, j) == (ei, ej): break # 如果老鼠找到了出口 for di, dj in [(0, -1), (0, 1), (-1, 0), (1, 0)]: # 左右上下 if maze[i + di][j + dj] == 0: # 如果当前点可走 maze[i + di][j + dj] = 1 # 把当前点置为1 stack.append((i + di, j + dj)) # 把当前的位置添加到栈里面 break else: # 如果所有的点都不可走 stack.pop() # 退回上一步 return stack # 如果迷宫不能走则返回空栈 Maze = initMaze() # 初始化迷宫 result = path(maze=Maze, start=(1, 1), end=(5, 5)) # 老鼠开始走迷宫 print(result) # [(1, 1), (1, 2), (2, 2), (3, 2), (3, 1), (4, 1), (5, 1), (5, 2), (5, 3), (4, 3), (4, 4), (4, 5), (5, 5)]
后缀表达式求值
题目
计算一个表达式时,编译器通常使用后缀表达式,这种表达式不需要括号:
| 中缀表达式 | 后缀表达式 |
|---|---|
| 2 + 3 * 4 | 2 3 4 * + |
| ( 1 + 2 ) * ( 6 / 3 ) + 2 | 1 2 + 6 3 / * 2 + |
| 18 / ( 3 * ( 1 + 2 ) ) | 18 3 1 2 + * / |
编写程序实现后缀表达式求值函数。
思路
解决代码
#!/use/bin/env python
# _*_ coding:utf-8 _*_
operators = { # 运算符操作表
'+': lambda op1, op2: op1 + op2,
'-': lambda op1, op2: op1 - op2,
'*': lambda op1, op2: op1 * op2,
'/': lambda op1, op2: op1 / op2,
}
def evalPostfix(e):
"""
:param e: 后缀表达式
:return: 正常情况下栈内的第一个元素就是计算好之后的值
"""
tokens = e.split() # 把传过来的后缀表达式切分成列表
stack = []
for token in tokens: # 迭代列表中的元素
if token.isdigit(): # 如果当前元素是数字
stack.append(int(token)) # 就追加到栈里边
elif token in operators.keys(): # 如果当前元素是操作符
f = operators[token] # 获取运算符操作表中对应的lambda表达式
op2 = stack.pop() # 根据先进后出的原则,先让第二个元素出栈
op1 = stack.pop() # 在让第一个元素出栈
stack.append(f(op1, op2)) # 把计算的结果在放入到栈内
return stack.pop() # 返回栈内的第一个元素
result = evalPostfix('2 3 4 * +')
print(result)
# 14
背包问题
题目
有一个背包能装10kg的物品,现在有6件物品分别为:
| 物品名称 | 重量 |
|---|---|
| 物品0 | 1kg |
| 物品1 | 8kg |
| 物品2 | 4kg |
| 物品3 | 3kg |
| 物品4 | 5kg |
| 物品5 | 2kg |
编写找出所有能将背包装满的解,如物品1+物品5。
解决代码
#!/use/bin/env python # _*_ coding:utf-8 _*_ def knapsack(t, w): """ :param t: 背包总容量 :param w: 物品重量列表 :return: """ n = len(w) # 可选的物品数量 stack = [] # 创建一个栈 k = 0 # 当前所选择的物品游标 while stack or k < n: # 栈不为空或者k<n while t > 0 and k < n: # 还有剩余空间并且有物品可装 if t >= w[k]: # 剩余空间大于等于当前物品重量 stack.append(k) # 把物品装备背包 t -= w[k] # 背包空间减少 k += 1 # 继续向后找 if t == 0: # 找到了解 print(stack) # 回退过程 k = stack.pop() # 把最后一个物品拿出来 t += w[k] # 背包总容量加上w[k] k += 1 # 装入下一个物品 knapsack(10, [1, 8, 4, 3, 5, 2]) """ [0, 2, 3, 5] [0, 2, 4] [1, 5] [3, 4, 5] """
总结
以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。
# python
# 栈
# 堆栈
# 调用栈
# Python算法的时间复杂度和空间复杂度(实例解析)
# Python算法中的时间复杂度问题
# python算法题 链表反转详解
# python算法与数据结构之单链表的实现代码
# python算法与数据结构之冒泡排序实例详解
# 详解python算法之冒泡排序
# Python算法之图的遍历
# Python算法输出1-9数组形成的结果为100的所有运算式
# python算法演练_One Rule 算法(详解)
# python算法表示概念扫盲教程
# Python算法之栈(stack)的实现
# python算法学习之计数排序实例
# Python集成学习之Blending算法详解
# 创建一个
# 为空
# 第一个
# 遍历
# 是一个
# 所示
# 起始点
# 设置为
# 大波
# 可走
# 都是
# 运算符
# 不匹配
# 判断是否
# 第一颗
# 情况下
# 总容量
# 迭代
# 几个
# 如果你
相关文章:
如何在沈阳梯子盘古建站优化SEO排名与功能模块?
如何制作网站标识牌,动态网站如何制作(教程)?
如何挑选高效建站主机与优质域名?
韩国网站服务器搭建指南:VPS选购、域名解析与DNS配置推荐
怎么制作网站设计模板图片,有电商商品详情页面的免费模板素材网站推荐吗?
如何基于云服务器快速搭建网站及云盘系统?
移动端手机网站制作软件,掌上时代,移动端网站的谷歌SEO该如何做?
定制建站方案优化指南:企业官网开发与建站费用解析
广州美橙建站如何快速搭建多端合一网站?
,网站推广常用方法?
如何正确选择百度移动适配建站域名?
Android自定义listview布局实现上拉加载下拉刷新功能
宝塔Windows建站如何避免显示默认IIS页面?
公司门户网站制作流程,华为官网怎么做?
建站10G流量真的够用吗?如何应对访问高峰?
美食网站链接制作教程视频,哪个教做美食的网站比较专业点?
贸易公司网站制作流程,出口贸易网站设计怎么做?
小视频制作网站有哪些,有什么看国内小视频的网站,求推荐?
C++用Dijkstra(迪杰斯特拉)算法求最短路径
详解ASP.NET 生成二维码实例(采用ThoughtWorks.QRCode和QrCode.Net两种方式)
开心动漫网站制作软件下载,十分开心动画为何停播?
胶州企业网站制作公司,青岛石头网络科技有限公司怎么样?
如何通过西部建站助手安装IIS服务器?
C++如何将C风格字符串(char*)转换为std::string?(代码示例)
如何在腾讯云服务器快速搭建个人网站?
如何在阿里云域名上完成建站全流程?
Python文件管理规范_工程实践说明【指导】
一键网站制作软件,义乌购一件代发流程?
C#怎么创建控制台应用 C# Console App项目创建方法
教学网站制作软件,学习*后期制作的网站有哪些?
建站主机默认首页配置指南:核心功能与访问路径优化
外贸公司网站制作,外贸网站建设一般有哪些步骤?
大型企业网站制作流程,做网站需要注册公司吗?
如何制作公司的网站链接,公司想做一个网站,一般需要花多少钱?
如何快速搭建支持数据库操作的智能建站平台?
c# 在高并发下使用反射发射(Reflection.Emit)的性能
专业网站建设制作报价,网页设计制作要考什么证?
如何在万网ECS上快速搭建专属网站?
详解jQuery中基本的动画方法
如何选择网络建站服务器?高效建站必看指南
油猴 教程,油猴搜脚本为什么会网页无法显示?
个人网站制作流程图片大全,个人网站如何注销?
建站之星如何快速解决建站难题?
外汇网站制作流程,如何在工商银行网站上做外汇买卖?
建站之星体验版:智能建站系统+响应式设计,多端适配快速建站
建站之星IIS配置教程:代码生成技巧与站点搭建指南
完全自定义免费建站平台:主题模板在线生成一站式服务
建站之星后台管理系统如何操作?
沈阳个人网站制作公司,哪个网站能考到沈阳事业编招聘的信息?
建站之星如何开启自定义404页面避免用户流失?
*请认真填写需求信息,我们会在24小时内与您取得联系。