栈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)。
热门推荐
三叉神经痛新疗法:经皮微创介入治疗了解一下?
成都军建医院教你预防三叉神经痛
复旦大学最新研究揭秘三叉神经痛:发现情绪障碍新机制
《我是你的菜》教你精准调配麻辣烤鱼调料比例
当心!这些“传统”烹饪习惯可能并不健康
冬季上火不用愁:中医两个小妙招助你轻松降火
印第安文化消失背后的殖民阴影
结肠息肉患者必看:五类食物助力肠道健康
女生素来裤边成常态,专家详解阔腿裤选购要点
盐城八大景点:从海滨度假到古镇文化,尽显海盐古城魅力
计算机科学与技术专业指南:五大领域核心技能详解
桥洞力学板实木复合门:隔音又环保,装修必选!
防盗门打不开?这些神操作让你秒变修门达人!
防盗门卡住了?这几个小窍门救场!
天长换锁教你正确清洁保养门锁
盐城盐业考古获重大突破,95后考古人解码千年文明
西游师徒四人:慈悲、勇敢、憨厚、忠厚的性格魅力
保险公司如何渡过利差损之劫?
最新报告:降息高峰期,存款利率进入“1”时代
颈椎疼吃布洛芬片管用吗
杭州经典两日游:从三潭印月到西溪湿地
鱼和熊掌不可兼得:解读一个关于取舍的中国智慧
AHP层次分析法:将复杂决策问题结构化的科学方法
1988年以前出生的人注意!今天再忙也要看一下
AHP层次分析法详解:原理、步骤与MATLAB实现
1988年属龙人2025年运势运程全解析
1988年生辰八字详解:戊辰年土命人的性格与命运
山西甑糕的营养秘密:每100克含161千卡热量,富含蛋白质和碳水化合物
山西甑糕的家庭秘制教程
西安甑糕:三千年传承的宫廷美味