栈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)。
热门推荐
机油保养周期灵活调整,低频用车可延长至一年
养三胞胎停演十年,宋一国综艺首谈育儿心路
翡翠手串和牌子哪个更有收藏价值?
中国手串海外爆火,文化魅力与时尚潮流的完美结合
信我!戴手串也可以时髦得要命!
小心了!手串圈正流行的这5种石头,或会让你付出健康的代价!
蓝珀手串怎么盘玩保养好看:变化与维护指南
货币符号设计进化:标准化与个性化的新平衡
如何缓解肚子胀气?6个小妙招让你轻松摆脱不适感
肚子胀气难熬?探究肠胃不适根源及有效缓解方法
高压点火线:新能源汽车的关键技术解析
电火花加工技术在航空航天的应用
电火花加工技术助力航空航天新材料突破
行车记录仪停车后还能监控吗?
深海开发需谨慎:从技术风险到生态平衡的双重考验
AI驱动就业转型:新职业崛起与传统岗位消退
AI重塑就业格局,科技公司月裁3.2万员工
报案指南:三种方式、三部门受理,7天内决定是否立案
奶茶咖啡因含量揭秘:最高竟达480mg/杯!
芙蓉镇攻略:瀑布夜景最迷人,2-3天玩转湘西古镇
避开人潮,探访这10个保留原始风貌的中国古镇
湖南八大古镇:从凤凰到德夯,湘西深处的古朴之美
芙蓉古镇深度游:2天行程+必打卡景点+美食住宿推荐
百年愿景照进现实:钦州港从“有海无港”到全国前十
山楂:心血管健康的新宠儿?
王者荣耀:一代野王典韦为什么现在处境这么尴尬?
制造业利用外资比重提升46%——西安何以“逆势”上扬
幼儿园巧用腊八节童谣,传统文化教育焕发新活力
西安国资大动作:“工投”或购华仁药业
腊八节童谣:一碗腊八粥里的民俗文化传承