求 《数据结构》中 二叉树 的一道程序题

来源:百度知道 编辑:UC知道 时间:2024/05/27 10:12:34
题为: 运用二叉树的知识设计一个程序将一数学表达式分别转换为前缀表达式和后缀表达式。( 哪位高手帮忙写一下程序,用 C语言,感激不尽!!! )
非常感谢 !!因为我们这星期三要交这个作业,我在VC6.0下可运行了,有一处错误,可是本人太笨,不会改,纠结呀,您能在试一下嘛,用一个数学表达式,运行一下,然后把结果也贴出来,感激不尽 ……

中缀表达式到后缀表达式的转换
要把表达式从中缀表达式的形式转换成用后缀表示法表示的等价表达式,必须了解操作符的优先级和结合性。优先级或者说操作符的强度决定求值顺序;优先级高 的操作符比优先级低的操作符先求值。 如果所有操作符优先级一样,那么求值顺序就取决于它们的结合性。操作符的结合性定义了相同优先级操作符组合的顺序(从右至左或从左至右)。
转换过程包括用下面的算法读入中缀表达式的操作数、操作符和括号:
1. 初始化一个空堆栈,将结果字符串变量置空。
2. 从左到右读入中缀表达式,每次一个字符。
3. 如果字符是操作数,将它添加到结果字符串。
4. 如果字符是个操作符,弹出(pop)操作符,直至遇见开括号(opening parenthesis)、优先级较低的操作符或者同一优先级的右结合符号。把这个操作符压入(push)堆栈。
5. 如果字符是个开括号,把它压入堆栈。
6. 如果字符是个闭括号(closing parenthesis),在遇见开括号前,弹出所有操作符,然后把它们添加到结果字符串。
7. 如果到达输入字符串的末尾,弹出所有操作符并添加到结果字符串。

#include<iostream>
#include<string>
#include<stack>
using namespace std;
int main()
{
string s;
string result;
stack<char> mystack;
char tmp;
cin >> s;
for (int i = 0; i < s.length(); i ++)
switch (s[i])
{
case '+':
case '-':
while (!mystack.empty())
{
tmp = mystack.top();
if (tmp