栈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)。
热门推荐
带娃游西安最佳季节:秋季胜在气候宜人活动丰富
赵志芳&卢旺盛教你磁共振前假牙处理
磁共振检查,你的假牙会“飞”吗?
全瓷假牙 vs 金属假牙:谁更适合核磁共振?
大唐不夜城推童话节,兵马俑亲子游攻略
西安亲子游完全攻略:行程规划、景点推荐与实用贴士
西安亲子游完全指南:兵马俑、大雁塔、古城墙
告别大肚腩,这些腹肌训练火遍全网!
高蛋白饮食,助你快速雕刻腹肌
医疗护航战斗力:现代军事医疗体系全解析
合川三庙镇斗牛石:大自然的魔法与千年传说
奥美拉唑正确服用指南,护航食管健康
重庆斗牛石:网红打卡地的神秘传说
合川三庙镇斗牛石探秘:自然奇观与文化传说的完美融合
奥美拉唑镁:食管炎患者的福音?
艾司奥美拉唑镁患者的饮食管理指南
冬季美食DIY:无骨鸡爪简易教程
古人是如何叫心上人的?这些称呼比“宝贝”还甜!建议收藏
"情人之眼":乔治四世与玛丽·菲茨赫伯特的皇室恋情见证
林微云:“情人之眼”的魔力
为了追求寡妇,年轻的王子竟然送上他的眼睛,著名的“情人之眼”
原神手鞠游戏攻略:三个地点分布与技巧详解
川牛膝种植技巧,让你家药园更丰盈
川牛膝:中医界的“万金油”
重阳节,来福建这两大徒步圣地登高
科学饮水,助力备考!
世界药师日:儿童家庭小药箱必备药品清单及用药指南
39度高烧应对全攻略:及时就医是关键
水墨画教程之梅花花朵的两种技法
真香!扬州闻香寻梅正当时