栈Stack——递归替身?
创作时间:
作者:
@小白创作中心
栈Stack——递归替身?
引用
1
来源
1.
https://www.cnblogs.com/ashet/p/18409599
在编程中,递归是一种常见的算法设计方法,但在处理大量数据时可能会导致栈溢出。本文将介绍Stack数据结构如何作为递归的替代方案,特别是在单向链表反转打印等场景中,使用Stack可以节省内存空间。
对于Stack这个集合类,由类继承关系可知是Vector的子类,根据push入栈方法跟踪代码,可知Vector是一个线程安全的类(高并发场景下使用,那可能不是一个好的选择)
看到这里,显然可以得知Stack入栈出栈的大致原理,就是Vector的
elementData对象数组
,用来储存数据,入栈时依次存放,出栈时倒序从数组中取出即可
在单向链表反转打印这样的场景中,我们可以很自然地想到使用递归来实现,相比递归我们可以使用Stack类依次将单向链表的
Node节点
存放至Stack的对象数组中,然后反向出栈取出即可。
public void reversePrint(Node node) {
Stack<Node> stack = new Stack<>();
while (node != null) {
stack.push(node);
node = node.next;
}
while (!stack.isEmpty()) {
System.out.println(stack.pop());
}
}
public void recursion(Node node) {
if (node.next != null) {
recursion(node.next);
}
System.out.println(node);
}
显然,在链表中节点元素较多的场景下,使用Stack的方案明显所需的memory更少。我们可以根据这个简单的示例,在递归场景下优先考虑Stack方案的可能性~(使用了数据结构来优化:方法调用所需要的内存空间)
当程序执行一个方法时,它会在调用栈上创建一个新的栈帧(Stack Frame)。这个栈帧包含了执行该方法所需的所有信息。当方法执行完毕并准备返回时,它的栈帧会从调用栈中弹出,控制权返回给调用者。
对于递归方法,每次递归调用都会创建一个新的栈帧,并将其推入调用栈中。如果递归调用过深,即调用栈中的栈帧数量超过了系统或JVM(Java虚拟机)等环境为调用栈分配的内存限制,就会发生栈溢出错误(StackOverflowError)。
热门推荐
AI人脸融合技术:探索面部识别与融合的奥秘
守护膝关节:轻松解锁日常运动的正确方法
被告信息不明确无法立案怎么办
《狂飙》引进韩国引发激烈讨论,国际化反响强烈成全球话题焦点
办强办优基础教育,中小学校长何为
新疆春季转场有了更多“现代范”
美联储降息,为何外汇市场黄金影响这么大?
985中外合作办学有哪些 能保研吗
没有工作也能申请房贷?这些替代方案了解一下
曝气生物滤池技术:工作原理与应用
我为什么这么懒?——懒惰的多维解析与深层机制
Excel公式向导使用指南:10种高效查找和使用方法
怎么查看Excel表格用了什么函数
摄影曝光:曝光模式认知
守护平安的“空中尖兵”:古浪公安多场景应用无人机赋能现代警务
WPS办公软件中去掉表格的三种方法
去皮鸭腿和鸡腿哪个热量高?一文读懂热量差异与健康饮食建议
欧盟智能船舶发展路线图
基建投资是什么意思?基建投资对经济增长的推动作用如何体现?
肾功能不全的详细饮食禁忌
二苯基甲烷二异氰酸酯(MDI)的应用与标准
故意伤害的违法行为可以调解吗
万兆交换机:中小企业办公网络解决方案
注册中级安全工程师备考资料全集,助你高效通关考试
年轻人,先买房还是先买车?
温室大棚的设计参考方案
手机重置打开方式_手机重置打开方式是什么
八字揭示五行命运 如何通过八字判断五行
Excel中INDEX函数的全面解析与实战应用
如何判断狗狗的健康状况?(掌握这三个主要指标,让你了解狗狗的身体状况。)