数据结构之"逆波兰树"求解算式 [a + b * (c - d) - e / f]

本文介绍了如何使用逆波兰树(非官方名称)解决算术表达式,如[a + b * (c - d) - e / f]。通过构建二叉树并进行前序和后序遍历来求解结果。在C语言实现中,重点讨论了指针和二级指针的使用,而在C++实现中则涉及引用的概念。示例计算给出了相同的结果:-3。
摘要由CSDN通过智能技术生成

逆波兰树加引号是因为这是我给她起的名字。。莫名喜感。一个算式的”波兰树“的构建并不是唯一的,这个得看个人的选择,选择括号外面的加号或减号作为树根。然后将剩下的算式依次拆分。将算术符号用子二叉树的根节点代替,数值用二叉树的左右子节点代替,这样就得到了一棵所求算式的波兰树,然后将其变化为扩充二叉树,得出她的前序遍历序列。然后通过一个创建波兰树的函数   Get_bolantree();,从而得到一个由head 头指针所代表的二叉树,再通过后序优先次序遍历函数,在便利的过程中通过一个栈求出最终结果。。


我想着重说的是,整棵二叉树的连接是通过指针的形式连接的。。所以说在main();函数里要定义一个指向结构体名的指针。

刚开始做我是和创建单链表一样用结构体名创建了一个结构体的对象,但是Get_bolantree();中需要对指针的左或者右指针进行操作。所以说传参时要传指针的地址,然后形参则是用一个二级指针接收。在函数中的操作一定要记住是对treenode head; 这个指针进行操作的。所以说对data赋值时需要先“取值”再赋值。递归同理。(C语言思想)。

如果是用C++思想做的话,传实参时直接传对象就可以,但形参接收的时候就要改成引用的形式。。而且在Get _bolantree();中就可以直接用引用名对指针进行操作了。。。

主要的还是得好好理解一下指针以及二级指针的操作。

运行结果如下:


C思想下的操作:


请输入构建[a + b * (c - d) - e / f]波兰树的字符串:


-+ann*bnn-cnndnn/ennfnn


请输入字母及其所代表的数值:


a 1
b 2
c 3
d 4
e 6
f 3


该波兰树的后序优先次序、也就是逆波兰式为:


abcd-*+ef/-


最终结果为: -3


内存已被成功释放。


C++思想下的操作:


请输入构建[a + b * (c - d) - e / f]波兰树的字符串:


-+ann*bnn-cnndnn/ennfnn


请输入字母及其所代表的数值:


a 1

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值