ICode9

精准搜索请尝试: 精确搜索
首页 > 编程语言> 文章详细

java – 用于计算表示算术表达式的二叉树的非递归方法

2019-07-29 04:12:00  阅读:237  来源: 互联网

标签:java algorithm binary-tree


正如主题所述,我需要描述一种不使用递归来评估二进制算术表达式树的方法.没有给我任何其他细节或说明.

至于我对这些事情的理解,我需要模拟树的顺序遍历.假设我的教科书中概述了ADT方法的可用性,我有hasLeft(),hasRight(),left(),right(),isInternal()和isExternal()方法.我需要问我的教授我是否可以创建自己的方法,但是没有使用parent()方法,所以我可以遍历树.虽然,我有一个root()方法.

有人可能会指出我正确的方向来弄清楚如何做到这一点?我没有想到没有递归的方法,因为我没有立即跳回树的方法.

解决方法:

您可以保留已经访问过的一堆节点.然后通过将新节点推入堆栈来替换递归调用,并从堆栈中弹出一个返回递归函数的节点.

请记住,在执行递归函数时,总会有一个隐式堆栈记住每个函数调用中传递的参数.

标签:java,algorithm,binary-tree
来源: https://codeday.me/bug/20190729/1568850.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有