栈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)。
热门推荐
体检发现动脉斑块怎么办?别慌!科学应对是关键
为何同一学校有多个报考代码?深入了解中外合作办学!
读书笔记写作技巧:提升理解力与思维能力的实用指南
稷下追光者:李振声院士的科学人生与桑梓情怀
托卡尔丘克出新书:女性需要面对自己在文学作品中的缺席
国防科技大学:科技强军的摇篮
空气炸锅使用安全指南:如何避免火灾及正确处理方法
竺领非凡丨竺晓凡教授深入解读团队EHA入选研究——儿童白血病篇
汽车保养必修课:火花塞更换周期与维护指南
烧烤食材清单大全(30年烧烤师傅分享各种烧烤配料和制作过程)
米兰双雄会师决赛,历史上正式比赛第三场海外米兰德比将打响
龙抄手:鲜醇爽滑里的成都味觉瑰宝
衡山,何以“寿岳”?
论文如何引用参考文献
GTA5神秘武器全解析(揭秘游戏中最强装备的获取与使用)
草莓吃了会上火吗
银行理财产品的投资风险预警机制?
2024 年中国水产品加工行业的快速增长与挑战概览
腹泻反复不好,肠道微生态到底扮演了什么角色?
手机摄影进阶:掌握运镜技巧,拍出电影感视频
劳动精神:法律行业的核心价值与实践指南
二战各国死亡人数排名,看到中国的死亡人数后,我泪目了!
紫色风情:搭配与妆容全方位解读,演绎独特色彩与迷人气质
如何顺利进入华硕主板BIOS的详细指南与注意事项
利用AI提升论文写作效率:高效提示词指南
如何选择合适的衣服尺码?一篇详尽指南教你如何选购服装
圓滿愛檸檬生乳酪蛋的熱量與營養價值解析
《实战伤寒论》:庞龙老师特别强调“六经辨证”的重要性
猪油与植物油的较量,你站哪一边?
文学3大主题之:生命的意义