栈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都江堰:谁才是真正的道法高手?
《道德经》里的道法自然,你真的懂了吗?
台湾茶室现致命米酵菌酸,无色无味1毫克可致死
TVB花旦转行卖面包,曾志伟剪彩成龙送花篮,顾客排长龙生意兴隆
买房必看:选择房贷银行的六大关键因素
老北京铜锅涮肉,健康吃法全攻略
未来厨房革新:厨具企业的智能化转型之路
专业建议:五步化解房贷断供风险
毕节炒饭健康吃法大揭秘
王翦灭燕:战国版“神操作”
提肛运动,便秘克星?
揭秘移动硬盘黑科技:如何助力千帆大模型开发与服务平台
手腕腱鞘炎康复操,拯救你的手腕
家庭自制蛋挞,烘焙达人必备技能!
金刚石砂轮:提升合金钢车刀磨削质量的关键利器
CBN砂轮:合金钢车刀磨削的利器
社区健康驿站:守护居民健康的温馨港湾
阿司匹林服用全指南:从时间到禁忌,这些要点要记牢
冬季宝宝发烧护理指南:物理降温+合理用药双管齐下
女贞子与旱莲草泡水的功效与注意事项
假期生病与皮质醇水平有关,专家:可通过运动饮食预防
从成分到副作用:一文读懂阿司匹林的正确使用方法
电热毯安全指南:正确选购和使用方法详解
柚子、橘子、橙子:三种柑橘类水果的营养差异解析
如何分辨库存车?这些细节不容忽视
2024年温州高中招生政策解读:录取率提升,分配生政策优化
白发长在哪,病就从哪来?这3处地方尤其要注意
浙江遂昌金矿公园:千年金窟变身旅游胜地