数据结构——栈和队列的应用

1.栈在括号匹配中的应用

算法的思想如下;

1)初始设置一个空栈,顺序读入括号。

2)若是右括号,则或使置于栈顶的最急迫期待得以消解,或是不合法的情况(括号序列不

匹配,退出程序)。

3)若是左括号,则作为一个新的更急迫的期待压入栈中,自然使原有的在栈中的所有未消解的期待的急迫性降了一级。算法结束时,栈为空,否则括号序列不匹配。

2.栈在表达式求值中的应用

①中缀变后缀

从左到右遍历,遇到数字直接写下来,遇到符号,优先级大的可以直接放入栈中,遇到同等优先级的先把栈中的出栈,在入栈。

②后缀变中缀

数字直接入栈,遇到符号,取出两个栈顶元素,与符号进行运算后入栈。

③中缀变前缀

从右向左遍历中序,方法跟中缀变后缀一样,结果也要从右往左写。

④前缀变中缀

从右向左遍历前缀序列 ,方法跟后缀变中缀一样。

3.栈在递归中的应用

递归是一种重要的程序设计方法。简单地说,若在一个函数、过程或数据结构的定义中又应用了它自身,则这个函数、过程或数据结构称为是递归定义的,简称递归。

它通常把一个大型的复杂问题层层转化为一个与原问题相似的规模较小的问题来求解,递归策略只需少量的代码就可以描述出解题过程所需要的多次重复计算,大大减少了程序的代码量。但在通常情况下,它的效率并不是太高。

以斐波那契数列为例,其定义为

int Fib(int n){

if(n==0)

return 0;

else if(n==1)

return 1;

else

return Fib(n-1) + Fib(n-2);

}

4.队列在层次遍历中的应用

该过程的简单描述如下:

①根结点入队。

②若队空(所有结点都已处理完毕),则结束遍历:否则重复③操作。

③队列中第一个结点出队,并访问。若其有左孩子则将左孩子入队;若其有右孩子,则将右孩子入队,返回②

相关推荐
牛油果子哥q9 分钟前
unordered_set / unordered_map 底层哈希表精讲,哈希原理、哈希冲突、链地址法、源码结构、有序与无序容器终极选型全解
数据结构·算法·哈希算法·散列表
进击的荆棘13 分钟前
优选算法——优先级队列
数据结构·c++·算法·leetcode·优先级队列
牛油果子哥q22 分钟前
哈希表经典刷题模型与布隆过滤器精讲,哈希查重、哈希计数、双哈希映射、误判原理与工业级落地应用
数据结构·算法·哈希算法·散列表
2601_9618451537 分钟前
花生十三图推思维导图|图形推理|技巧
数据结构·算法·链表·贪心算法·排序算法·线性回归·动态规划
前进吧-程序员38 分钟前
反转链表完全指南:辅助容器、三指针、头插法
数据结构·c++·链表
程序猿零零漆1 小时前
Python进阶之路:正则表达式、高级语法与核心数据结构(链表、二叉树)全解析
数据结构·python·正则表达式
lihao lihao1 小时前
Linux线程同步与互斥
linux·数据结构·算法
海清河晏11116 小时前
数据结构 | 八大排序
数据结构·算法·排序算法
liulilittle16 小时前
固定数组时间轮的槽过载优化:桶链表与批次执行
网络·数据结构·链表
Irissgwe17 小时前
数据结构-栈和队列
数据结构·c++·c·栈和队列