栈Stack——递归替身?

news/2024/11/15 11:29:50/文章来源:https://www.cnblogs.com/ashet/p/18409599

 

对于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)。

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/795871.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

煤矿反光衣穿戴识别系统

煤矿反光衣穿戴识别系统对视频监控画面开展实时识别分析,可以及时预警施工工地工作员是不是按照规定穿反光衣。当煤矿反光衣穿戴识别系统发现视频监控界面中有工作人员不穿反光衣时,系统会积极主动开启警报提示。工程师依据煤矿情景开展有目的的算法优化。本优化计算方法具有…

如何彻底关闭Win11自动更新?

如何彻底关闭Win11自动更新?https://www.disktool.cn/content-center/stop-windows-11-update-666.html1、“Win+R”调出运行,输入“services.msc”,回车打开服务。  2、找到“Windows update”,打开。  3、设置为“禁用”,然后点击“停止”。方案一:使用Windows设置…

释放静电行为监测识别系统

释放静电行为监测识别系统对烟花爆竹厂进入车间的入口处进行实时监测分析,当释放静电行为监测识别系统监测一部分员工进到车间之前并没有触摸静电释放仪,系统就会自动开启警报同时语音提醒工人触碰静电释放器释放静电,并把警报截屏和视频保存到下来生成表格,推送给有关人员…

监控视频行为分析系统

监控视频行为分析系统是可以通过利用现场监控摄像头传回的现场画面视频利用AI神经网络模型的人工优化算法分析识别人们运动轨迹,监控视频行为分析系统去识别监控摄像机拍摄到的各种人的异常行为,甚至很多行为识别规则大多数场景下都可以做到零误报。这大大降低了系统对硬件的…

洛谷题单指南-分治与倍增-P1966 [NOIP2013 提高组] 火柴排队

原题链接:https://www.luogu.com.cn/problem/P1966 题意解读:计算两个序列∑(ai​−bi​)^2的最小值,对10^8-3取模。 解题思路: 1、贪心思路 要使得两个序列对应位置元素之差的平方和最小,必须满足两个序列相对排序是一致的,什么意思? 设a序列有两个元素:a1,a2,b序列…

两款插件让浏览器起飞!

今天给大家分享两款最近在用的实用小插件~1.猫抓 一个用来帮我们嗅探下载网络上各种媒体资源的小插件 当我们浏览的网站有媒体文件时,插件就会自动嗅探视频资源。这时我们只需要点开插件页面,直接下载就好了。不单单是普通的媒体文件,遇见M3U8这种分段式格式,插件还会自动…

养老院视频监控分析系统

养老院视频监控分析系统24h不需要人员监控,对养老院360度及时高清视频监控,即时自动分析和识别养老院监控区域内的异常情况。一旦出现异常,养老院视频监控分析系统马上记录和储存,并把报警信息上传至综合服务平台。除此之外,依据智能视频分析,识别监控区域内的工作人员入…

值班人员睡岗离岗监控报警系统

值班人员睡岗离岗监控报警系统可持续24个小时对值班岗位开展智能化监控。目前,值班人员睡岗离岗监控报警系统识别工作员长时间保持不动的姿态,会被判定为睡岗,随后马上提醒睡岗工作人员。值班人员睡岗离岗监控报警系统同时保存前端分析视频证据并上传至后台,为后续的人工审…

不升级 POI 版本,如何生成符合新版标准的Excel 2007文件

开心一刻 记得小时候,家里丢了钱,是我拿的,可爸妈却一口咬定是弟弟拿的 爸爸把弟弟打的遍体鳞伤,弟弟气愤的斜视着我 我不敢直视弟弟,目光转向爸爸说到:爸爸,你看他,好像还不服问题描述 项目基于 POI 4.1.2 生成 Excel 2007 文件,已经对接了很多客户,也稳定运行了好…

个人简历生成神器!一款在线简历制作工具!

codecv —— 一款制作简历的工具,帮助你以 Markdown 的简洁语法快速编写生成专业的简历,并支持转为 PDF 保存,还提供了海量模板。大家好,我是 Java陈序员。 九月、十月对于广大的程序员来说是找工作的好时节,俗称“金九银十”!无论是社招,还是校招,找工作都需要一份好的…

关于一些字符串操作的常用方法

字符串操作 关于一些字符串操作常用方法 字符串截取string temp = "大家好, 我叫张三。";//索引从0开始截取索引5后面的所有字符串(包括5)Console.WriteLine(temp.Substring(5));//索引从0开始,截取索引5后面4个字符串(包括5)Console.WriteLine(temp.Substring(5, …

前端vue2 常用的函数

1、在el-menu开启路由模式,default-active使用动态值等于当前路由,就需要用:default-active="$route.path" 2、阿里巴巴矢量图icfont的使用①将自己需要的图标下载到矢量库对应的项目文件中 ②更新对应的css代码,点击css代码链接,更新到本地去 ③使用<i class…