栈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)。
热门推荐
香港银行账户类型:了解不同类型账户的特点和适用场景
留学生行李打包全攻略:行李额度、超重应对与打包技巧
智能空开出现故障提前告警!
初中三年学习重心与策略指南:精准把握,高效逆袭
西安4日游最佳路线
北京冬天游攻略(北京自由行详细攻略)
高钙蔬菜有哪些食物排行表
游戏党必看 HDMI 2.1大揭秘!解锁影音新视界
有糖尿病、高血压可以做白内障手术吗?武汉普瑞眼科医生来解答
如何预测周一黄金市场的走向?这种预测的依据和方法是什么?
如何评估一个地区的居住环境?这种评估方法如何帮助我们做出更好的居住选择?
中性洗剂完全指南:成分、用途、使用方法及推荐产品
中部战区陆军部队实战化训练:全时待战,随时能战!
金牛山上的抗战故事
清明祭扫,这样烧纸要不得
腰痛救星!5个睡姿改善腰椎压力
12道鸡翅家常菜,风味绝绝子,解馋滋补又下饭,美食被夸爆
非遗民俗的齐鲁风华:在传承与创新中焕活千年文脉
新入职员工培训计划怎么制定才科学?
被起诉离婚对孩子的影响及法律分析
皮肤松弛要补充什么维生素?
玄奘西行的历史评价
总经理和总裁的区别和联系
一线调研|八年试点,全面建设“搭把手、喘口气”的长护险还有哪些挑战?
五指山:热带雨林与民族文化交融的旅游胜地
2025年房价是否会继续下跌?数据告诉你真相
早上起来头昏脑胀的是什么原因
甲亢病人一日三餐食谱
解析L4级无人驾驶在高速公路上的实际应用与挑战
如何选择高品质的床垫?床垫对睡眠质量的影响是什么?