免费注册 查看新帖 |

Chinaunix

广告
  平台 论坛 博客 文库
论坛 程序设计 C/C++ 2叉树
最近访问板块 发新帖
查看: 2320 | 回复: 7
打印 上一主题 下一主题

2叉树 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2007-07-25 15:21 |只看该作者 |倒序浏览
要计算1*(2+3),先转成逆波兰123+*,在利用栈就可以得到答案了。
树的后缀遍历就得到逆波兰式。有什么方法可以把1*(2+3)转成
2叉树?

论坛徽章:
0
2 [报告]
发表于 2007-07-25 15:44 |只看该作者
请使用bison。

论坛徽章:
0
3 [报告]
发表于 2007-07-25 19:33 |只看该作者
我对CU感到失望了


斑竹 如何注销ID?

论坛徽章:
0
4 [报告]
发表于 2007-07-25 19:43 |只看该作者
你对做人失望吗,小帅哥

论坛徽章:
1
荣誉版主
日期:2011-11-23 16:44:17
5 [报告]
发表于 2007-07-25 20:57 |只看该作者
干嘛要转化成二叉树才能计算呢?

论坛徽章:
95
程序设计版块每日发帖之星
日期:2015-09-05 06:20:00程序设计版块每日发帖之星
日期:2015-09-17 06:20:00程序设计版块每日发帖之星
日期:2015-09-18 06:20:002015亚冠之阿尔艾因
日期:2015-09-18 10:35:08月度论坛发贴之星
日期:2015-09-30 22:25:002015亚冠之阿尔沙巴布
日期:2015-10-03 08:57:39程序设计版块每日发帖之星
日期:2015-10-05 06:20:00每日论坛发贴之星
日期:2015-10-05 06:20:002015年亚冠纪念徽章
日期:2015-10-06 10:06:482015亚冠之塔什干棉农
日期:2015-10-19 19:43:35程序设计版块每日发帖之星
日期:2015-10-21 06:20:00每日论坛发贴之星
日期:2015-09-14 06:20:00
6 [报告]
发表于 2007-07-25 21:35 |只看该作者
原帖由 20080030成电 于 2007-7-25 19:33 发表
我对CU感到失望了


斑竹 如何注销ID?

直接不登录就完了。

论坛徽章:
0
7 [报告]
发表于 2007-07-27 08:58 |只看该作者
原帖由 20080030成电 于 2007-7-25 15:21 发表
要计算1*(2+3),先转成逆波兰123+*,在利用栈就可以得到答案了。
树的后缀遍历就得到逆波兰式。有什么方法可以把1*(2+3)转成
2叉树?


这个跟中缀转后缀是类似的。

以 a+(b+c)*d  为例子,你用两个栈,一个装符号,一个装指向二叉树的指针


  1. a b c
  2. + ( +              <-- )
复制代码


此时弹出 +, 并与 b c 结合,合并成二叉树 (+ b c),然后把指向这棵树的指针压回数据栈,得到


  1. a (+ b c)
  2. + (                 <--)
复制代码


象中缀转后缀那样继续


  1. a (+ b c) f
  2. + *
复制代码


现在串已经扫描完毕,做最后的处理


  1. a (* (+ b c) f)
  2. +
复制代码


  1. (+ a (* (+ b c) f))
复制代码


done.

[ 本帖最后由 局内人 于 2007-7-27 09:00 编辑 ]

论坛徽章:
0
8 [报告]
发表于 2007-07-27 09:12 |只看该作者
看看编译原理是怎么处理的,你就知道了。

简单点说:

就是从左->右扫描字符串,为操作数建树节点(即叶子节点)、为操作符建立树节点(非叶子节点),同时考虑算术符号的优先级,即可建立2X树。
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP