栈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)。
热门推荐
白醋蜂蜜能减肥吗?科学解读其功效与局限
客家土楼蕴含的人文精神
永定土楼旅游住宿攻略:8个特色住宿推荐
龙岩旅游攻略景点大全,龙岩旅游必去十大景点有哪些?看这里!
股权转让违约责任条款怎么写
2024年中国信托行业市场结构分析:证券市场成信托资金投资重点
穿戴甲多久可以碰水?不同材质和场景下的护理指南
穿戴美甲需要每天都摘卸吗?揭秘美甲护理的科学之道!
中文名字该如何翻译成英文
从A到Z的餐厅术语指南:餐饮业专业词汇大集合
AI游戏搬砖机器叫什么?揭秘游戏界的新型助手
武汉到北海:三种交通方式全面对比,哪一种最划算?
武汉到北海:秋冬旅游必备攻略
纣王之死:历史小说中的不同演绎
艾灸5大穴位,告别眼干、眼涩和眼疲劳
艾灸是否能够有效治疗眼睛近视?探讨艾灸对近视的潜在疗效与机制
艾灸是否能够有效治疗眼睛近视?探讨艾灸对近视的潜在疗效与机制
你洗笔的方法,对吗?|百画苑·油画
央妈出手!债基投资如何应对?
苏轼《定风波》:黄州时期的豁达人生
一蓑烟雨任平生:苏轼在黄州的心路历程
纪录片《定风波》:一位千古名家的传奇人生
岁数大了,煮鸡蛋、煎鸡蛋还是卤鸡蛋?科学上如何选择?
15种高蛋白鸡蛋减肥食谱
曹操《观沧海》:古代文人心境的现代解读
王充闾与温庭筠的禅意诗:心静与超脱
李白苏轼教你如何超脱世俗
李白《静夜思》:明月照耀下的孤独与乡愁
上海到厦门自驾游:1600公里的海岸线之旅
枸杞岛&嵊山岛:沈海高速沿线的海岛度假胜地