栈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)。
热门推荐
连州地下河探秘,旅游文化季正热🔥
冬日避寒打卡:连州地下河
我的世界建造下界传送门教程
亲子互动英语:让学习更有趣,让陪伴更有意义
无锡医保刷脸支付,告别排队烦恼
北京医保码推广,智慧医保新体验
谁不生育?:无子女现象背后的多样生命历程
购房税费大盘点:契税、维修基金等占比详解
重庆房贷利率降至3.6%,月供最高降886元
辽宁兴城自由行:古城海景美食全攻略
白芷小茴香等香料炖鸡效果好,焯水反而无用
每周必吃8次的酱油鸡:这样做酱香浓郁,鸡肉嫩滑
鲜嫩多汁的鸡腿炖法:选材、烹饪到收汁全解析
黄金灯鱼饲养全攻略(宠物爱好者必看)
江浙沪最美徒步线路推荐:三条精选路线带你亲近自然
江浙沪必打卡景点,周末游攻略新鲜出炉!
江浙沪三大打卡圣地:外滩、拙政园、西湖
低脂低胆固醇的鸵鸟肉,营养价值全面解析
如何平衡拔尖与公平?特尖生班动态进退机制的探索与思考
如何挑选优质土豆,让你的炒土豆丝更脆爽?
清炒土豆丝,健康吃法大揭秘!
炒土豆丝英文教程:让你秒变厨艺达人!
春节倒计时:最潮新年贺词大比拼
新年祝福语,让你的老师感动不已
海鲜市场的现状及发展趋势分析
煮熟螃蟹如何保存
料理螃蟹鲜甜饱满的秘诀 避开9个误区
LED色容差标准与控制:影响因素及解决方案
智能舞台灯光控制系统:技术创新驱动舞台艺术升级
婚姻幸福密码:夫妻沟通的艺术