逆波兰树加引号是因为这是我给她起的名字。。莫名喜感。一个算式的”波兰树“的构建并不是唯一的,这个得看个人的选择,选择括号外面的加号或减号作为树根。然后将剩下的算式依次拆分。将算术符号用子二叉树的根节点代替,数值用二叉树的左右子节点代替,这样就得到了一棵所求算式的波兰树,然后将其变化为扩充二叉树,得出她的前序遍历序列。然后通过一个创建波兰树的函数 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