栈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)。
热门推荐
专家提醒:不痛的结石更可怕
甘肃华亭:“共享菇棚”蹚出村集体经济新路径
欧协联1/8决赛前瞻:皇家贝蒂斯VS吉马良斯——西甲劲旅与葡超黑马的碰撞
超越千兆的“百元计划”
天南重地——雷州文化
软件测试工程师的薪资待遇与哪些技能相关?
城大研发新型催化剂 实现高性能可充电锌-硝酸盐电池
如何设计复杂的算法公式
AI绘画创作指南:从入门到精通的提示词使用全攻略
音乐产业大咖齐聚北京,热议AI时代版权保护与行业未来
如何解决过度依赖?
蒸馏酒的年代溯至3000年前
美味清爽的鲜鱼豆腐汤(传统家常菜,健康营养必备)
《报告》预计:2024年煤炭市场供需将保持基本平衡态势
主要煤种价格变化(元/吨)
空气炸锅烤红薯:简单易做,美味爆棚
如何评估要解禁的股票的风险?这种解禁对投资者有何影响?
兄弟搭档到竞争对抗,周鸿祎与齐向东的16年合离
如何依规缴纳医疗补充保险?这种保险缴纳有哪些要求?
事故现场程序规定:确保安全与高效的应对措施
汽车事故处理的步骤是什么?这些步骤的先后顺序有何讲究?
一文带你了解古代武将的称号:杂号将军和重号将军以及他们的区别
湖南民族单招政策详解
突发心梗、脑梗时,第一时间不是打120,很多人可能做错了!
A股11月流通市值破78万亿创新高 市值管理热度升温
股票流通市值与市场流动性的关系如何?
胃的动力为什么越来越缓慢?胃动力不足,怎样才能加把力?
醉驾案件:法律适用与社会影响深度解析
背绿一角价格 背绿一角冠号大全
什么是伊朗货币的汇率波动?这种波动会带来哪些后果?