AST相关问题

荃子 2011-02-17 10:51:53
请问各位如何用抽象语法树实现 1+ 2 * 3 这样的例子?二叉树方式实现。
...全文
128 4 打赏 收藏 转发到动态 举报
写回复
用AI写文章
4 条回复
切换为时间正序
请发表友善的回复…
发表回复
a707000646 2011-02-18
  • 打赏
  • 举报
回复
其实也就是把这个式子利用栈的数据结构转化为前缀表达式然后再用先序遍历的方式保存再二叉树中
a707000646 2011-02-17
  • 打赏
  • 举报
回复
如果你是要实现计算着个式子的话
树可以保存算术的结构
但是如果要弄成计算器的话
还是使用栈效率更高
a707000646 2011-02-17
  • 打赏
  • 举报
回复
把他化成一个二叉树
前序遍历
我这里列出树的结构
根节点 +
+的左子树是乘号 右子树是 1
乘号的左子树是 2 右子树是3
然后先序遍历
得到的就是这个式子
荃子 2011-02-17
  • 打赏
  • 举报
回复
楼上兄台, 这个式子仅仅是例子,程序需要将加减乘除算式(例如上文举例 1+2×3)读入,返回计算结果,记的是用栈的效率处理更加高,能否提示一下?

64,682

社区成员

发帖
与我相关
我的任务
社区描述
C++ 语言相关问题讨论,技术干货分享,前沿动态等
c++ 技术论坛(原bbs)
社区管理员
  • C++ 语言社区
  • encoderlee
  • paschen
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告
  1. 请不要发布与C++技术无关的贴子
  2. 请不要发布与技术无关的招聘、广告的帖子
  3. 请尽可能的描述清楚你的问题,如果涉及到代码请尽可能的格式化一下

试试用AI创作助手写篇文章吧