栈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)。
热门推荐
唐朝皇后大盘点:盛世背后的女性身影
从日本带猫回国全攻略:手续、流程及注意事项详解
兰州公安"DeepSeek智警"开讲法治第一课
制定每周工作计划时,哪些选项需要特别注意
柳叶刀子刊发布中国呼吸道癌数据:发病率和死亡率双升
国家癌症中心发布全国癌症报告,这些数据你应该知道!
数字多媒体运营岗位必备的六大核心技能
开展义诊、组织献血…… 践行雷锋精神医务人员在行动
生理期可以喝奶茶吗?这份健康指南请收好
浅析股票投资的社会文化影响
牛肉炖汤要放什么搭配才好喝?五种牛肉“绝味”汤,开启舌尖美味
星露谷物语姜岛怎么去
深入了解有机茶:定义、标准、认证与选购指南
收入证明开具指南:注意事项与解决方案
聘用合同能否作为收入证明的有效法律文件?
揭秘!苏格兰为何执着于独立之路?
50个最具中国文化意义的汉字
汉字的传奇:从仓颉造字到现代汉字的千年演变
凡事有交代,件件有着落!真正的高手,赢在闭环思维
凡事有交代,件件有着落!真正的高手,赢在闭环思维
白色t恤怎么洗白 10个方法教你如何洗白色t恤
打造另一个宁波主城区?宁波北部综合交通枢纽正式落户慈溪……
安全教育:深度解析溺水的危害与预防措施
鸡减蛋综合征病毒血凝抑制试验抗原
四川省深入推进长江十年禁渔工作 水生生物多样性保护成效显著
粉色在艺术中的应用:探索色彩心理学
水质 碱度、碳酸盐和重碳酸盐的测定 自动电位滴定法
红薯是优质碳水吗
销售管理者如何跟进客户
六大策略:用数据分析提升私域直播电商、门店与社区团购运营效率