栈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)。
热门推荐
高尿酸血症能不能吃菠菜
券商行业,从业人数锐减近万人
强化社会监督 国家医保局加强医保基金社会监督员管理工作
腿总“闹脾气”,一到晚上就不安分?小心是不宁腿综合征在作祟!
篮球比赛中的十种基础战术详解
穿越千年,古诗词如何治愈现代人?
感激之情应该如何真诚表达
表演型人格障碍的特征是什么
“信任经济”下,付费内容的定价策略
揭秘司美格鲁肽:减重之外的惊人功效,Nature Medicine最新发现!
康熙字典中的"兆"字详解
Windows 11:「移动热点」使用指南,轻松创建 Wi-Fi 热点
把Windows主机打造成一个Internet网关,多主机共享互联网
上海医保卡余额使用指南:住院、门诊报销标准全解析
药食同源:玫瑰花、赤小豆、山楂、紫苏叶和鸡内金的多重功效
把华工贴在心尖尖上,这些新年窗花爱了~
男性补钙指南:哪些食物更有效?
三峡大学科技学院是公办还是民办大学?
肝内钙化灶患者的饮食指南:五类适宜食物推荐
给排水系统管理要点及注意事项
如何评估科技企业的投资价值?以浙江中晶科技为例
如何在无聊时找到生活的乐趣与新机会的探索
扫描电子显微镜(SEM)类型和原理
薄荷提取物的广泛应用
探秘四川青城山:道教圣地游玩攻略与趣味体验
肝脏低密度灶的可能病因、诊断方法及护理措施
肝内低密度灶是什么意思
琅勃拉邦之旅:老挝币换算全攻略
CNC加工工艺流程详解
提升工作效率的关键:如何设置电脑快捷键技巧与建议