栈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)。
热门推荐
荷兰豆要多久才熟
酷睿i7和i9有什么区别 一文看懂核心性能差距
户外骑行全攻略:准备与注意事项
炒饭热量:普通炒饭和加料炒饭的热量差异及控制建议
诗韵长白:颂扬仙境中的自然之美——《七律·咏长白山仙境》赏析
银行账户被限制交易?这些查询方法请收好
《寻道大千》连击暴击流搭配攻略
房屋买卖合同范本:押金条款详细说明
深观察丨春节的社会实践:确认“我们是谁”的节日
拼音:提升中文ASR纠错的秘密武器
压克力颜料清洗?8个实用方法大公开
卸妆乳、卸妆水、卸妆油:你真的了解它们吗?
打破壁垒,共防狂犬病 | 面对致死率100%的狂犬病不要疑惑,打它就是了
在作文中巧妙使用比喻
1分钟搞懂美国咋又一家银行倒闭了
入户花园怎样养好花卉?在入户花园养花的技巧有哪些?
租房管理系统的概念与发展探索提升租赁流程与用户体验的创新之路
房屋最佳朝向角度是多少?选择合适朝向提升居住体验
美食若镜,照见中国
中国最名贵的十大名菜,中国顶级美食盘点
约8%的人经历过鬼压床 别怕!应对方法来了
魔兽世界WLK怀旧服ToC版本痛苦术士玩法攻略
如何用穿搭展现个人魅力:从零开始打造你的风格指南
这5种走路姿势,可能是疾病征兆!
常见异常步态及矫治训练方法,图文详解值得收藏!
法条排序规范:让法律条文排序更有序
油烟净化器清洗维护的方法步骤及注意事项
这道杭州人从小吃到大的美味,主产地就在建德!这条路也与它有关……
十类学生必备户外用品有哪些 学生户外运动需要哪些装备
清明扫墓时间有讲究吗?这些注意事项请收好