栈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)。
热门推荐
孔雀小鱼苗的饮食习惯是什么?如何喂养它们?
新环境下猫咪老是叫怎么办(猫咪适应新环境的15个方法)
复式票是什么意思
宝宝大便带点血丝怎么回事
宝宝大便带点血丝怎么回事
老祖宗忠告:人睡三觉,命比纸薄!
甘草泡水可以止咳吗
活塞环磨损的常见症状有哪些?
三步走自测皮疹性质
碳排放因子的全方位解读:定义、计算与案例分析
2024杭州马拉松竞赛规程公布
伊邪那岐与伊邪那美:日本创世神话中的夫妇神
NBA选秀历史8位被选中的中国球员你都认识吗?1人签约后连续重伤
探访千年古村落——福建政和杨源村
西藏这座千年古村,大变样!
拨开迷雾!贝叶斯推理:读懂“不确定性”
"人工智能+"与各行业融合创新应用场景:探索未来发展趋势
怀瑾握瑜:探究其中的深意与文化内涵
房屋交易中的法律问题:抵押过户、备案与期房过户详解
装修避坑指南:三种情况必须铲墙皮,别让3000元打水漂
数字人的原理是什么 数字人的作用有哪些
塑料上面的胶如何去除?去除过程中有哪些关键步骤?
塞思·卡拉曼:热爱黄金的美国亿万富翁的传记
形象管理包括哪些项目和内容
公鸡是发物吗?这些人不宜食用
泡茶时一般放入适量茶叶的具体标准与技巧
晚清第一大案:戊午科场舞弊案始末
“当科学与艺术相遇”走近脑科学与中国传统音乐文化
如何管理客户回访制度
王者荣耀吸血装备大揭秘:战士坦克与射手英雄的生存与输出之道