栈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)。
热门推荐
牛奶瓶也能健身?5种自制器材让居家锻炼更省钱
湖北自驾之旅:潜江至恩施全程攻略
电路原理基础:从概念到应用的完整指南
插座上的L和N:火线零线如何保障用电安全
装修插座别再“踩坑”!7个常见错误要当心
唐嫣、倪妮、森绘梨佳的妆都是他们画的,怪不得像“发光肌”

分析了数百位现象级达人,我们找到了美妆赛道的3大趋势
Science:Notch信号调控肺泡再生,为肺损伤治疗提供新思路
新手司机驾驶技术提升全攻略:理论学习+六大软肋突破
首位AI助理爱芒的出现,是综艺与AI创新融合的新风向?
快快网络教你搞定《我的世界》服务器卡顿
梁启超后人过得怎样?一门三院士,九子皆才俊
买的车位还要交小区停车费用吗
车位管理费包括哪些服务项目
车位管理费不交就不能停车吗?一文详解车位管理相关法律问题
书香门第的荣耀:一组梁启超家族老照片
“一门三院士,九子皆才俊”,梁启超的子女为何个个优秀?
广东春秋游:气候宜人,活动多样
宁波赏杜鹃攻略:金峨山堵车,炮台岗清幽,影潭山惊艳
北部湾港:中国-东盟贸易枢纽的崛起与机遇
协商、调解还是诉讼?医疗纠纷处理途径指南
个人理财必修课:13个实用货币管理技巧详解
春节催收电话增多,专家支招:主动应对化解债务危机
济宁运河创新游览模式,日赏古迹夜观灯
济宁河道总督署遗址公园开放,六百年运河文化焕发新生
AI赋能内河航运,济宁智慧物流平台覆盖290个港口
周汤豪演唱意外后台急救!脚踝扭伤你还在冰敷?急性期5招正确应对减少肿胀
如何科学选择补钙产品?以步长碳酸钙咀嚼片为例
OCR技术助力医疗智能化:从手写识别到效率提升
深度学习让手写汉字识别飞速进化