栈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)。
热门推荐
为何德国的高速不限速,而国内高速就不行?主要是这几个原因
车辆跑高速的表现如何?怎样提升车辆在高速上的行驶体验?
绵阳旅游攻略:最佳旅游时间、景点推荐、美食与住宿建议
旅游市场供需变局凸显:酒店民宿预定量升价跌,节后高性价比出游延续
白条鱼的生活习性及特点
夏日探秘:介休张壁村&忻州古城
历史天空:辽朝的疆域
上饶水南街文化街区:文旅融合打造城市新地标
“饶帮菜”美食文化节引爆上饶夜经济
健康微课|冬季唇炎高发,如何预防?
嘴唇炎抹什么药膏?三种常用药膏及使用注意事项
唇炎反复发作,这些日常习惯居然是罪魁祸首
淄博集市摄影指南:捕捉最美年味
2025淄博元宵节民俗展演:传统与创新的完美融合
银行人员提醒:60岁以上老年人理财安全指南
六个案例说清楚遗嘱继承,建议收藏!
钟欣潼的优雅时尚穿搭秘诀:从配饰到高跟鞋的全方位指南
实用理财技巧:从存钱到财富自由
蜘蛛丝复合材料:航空航天领域的革命性新材料
第一次约会如何避免踩雷?这些禁忌要知道!
初次约会必看!6个心理学小技巧助你虏获芳心
第一次约会如何不踩雷?超实用攻略!
初中学生压力大焦虑怎么办?北京中学生心理疏导机构哪家好
初中生谈恋爱:引导正确处理,健康成长
明前期盛世文学视野下的“燕京八景”诗
燕京新语丨百年湖广会馆遇见国风音乐剧:一场《金风玉露》的文化奇遇
《玩命流氓》:波兰青少年的黑暗成长之路
《玩命流氓》:一个少年的黑暗与救赎之路
从古籍到大银幕,《哪吒2》带你穿越千年的神话之旅
互联网保险的特点及优势是什么