首页
学习
活动
专区
工具
TVP
发布
精选内容/技术社群/优惠产品,尽在小程序
立即前往

将中缀表达式(带括号)转换为二叉树

这个问题可以转化为一个典型的树形结构问题。我们可以使用一个二叉树来表示中缀表达式,其中每个节点表示一个操作,其左子树表示操作数,右子树表示操作符。

在将中缀表达式转换为二叉树时,我们需要遵循以下步骤:

  1. 首先,将中缀表达式的操作数转换为二叉树的左子树。
  2. 然后,将中缀表达式的操作符转换为二叉树的右子树。
  3. 最后,将左子树和右子树连接起来,形成二叉树。

以下是一个示例代码,实现了将中缀表达式转换为二叉树的功能:

代码语言:python
代码运行次数:0
复制

class TreeNode:

代码语言:txt
复制
def __init__(self, val=0, left=None, right=None):
代码语言:txt
复制
    self.val = val
代码语言:txt
复制
    self.left = left
代码语言:txt
复制
    self.right = right

def inorder_to_postorder(inorder):

代码语言:txt
复制
if not inorder:
代码语言:txt
复制
    return None
代码语言:txt
复制
root = TreeNode(inorder[0])
代码语言:txt
复制
i = 1
代码语言:txt
复制
while i < len(inorder) and inorder[i] == inorder[0]:
代码语言:txt
复制
    i += 1
代码语言:txt
复制
root.left = inorder_to_postorder(inorder[1:i])
代码语言:txt
复制
root.right = inorder_to_postorder(inorder[i:])
代码语言:txt
复制
return root

def inorder_to_preorder(inorder):

代码语言:txt
复制
if not inorder:
代码语言:txt
复制
    return None
代码语言:txt
复制
root = TreeNode(inorder[0])
代码语言:txt
复制
i = 1
代码语言:txt
复制
while i < len(inorder) and inorder[i] == inorder[0]:
代码语言:txt
复制
    i += 1
代码语言:txt
复制
root.left = inorder_to_preorder(inorder[1:i])
代码语言:txt
复制
root.right = inorder_to_preorder(inorder[i:])
代码语言:txt
复制
return root

def inorder_to_prefix_tree(inorder):

代码语言:txt
复制
if not inorder:
代码语言:txt
复制
    return None
代码语言:txt
复制
root = TreeNode(inorder[0])
代码语言:txt
复制
i = 1
代码语言:txt
复制
while i < len(inorder) and inorder[i] == inorder[0]:
代码语言:txt
复制
    i += 1
代码语言:txt
复制
root.left = inorder_to_prefix_tree(inorder[1:i])
代码语言:txt
复制
root.right = inorder_to_prefix_tree(inorder[i:])
代码语言:txt
复制
return root

def prefix_to_inorder(prefix, inorder):

代码语言:txt
复制
if not prefix or not inorder:
代码语言:txt
复制
    return None
代码语言:txt
复制
i = len(inorder)
代码语言:txt
复制
while i >= 0 and inorder[i] != prefix[0]:
代码语言:txt
复制
    i -= 1
代码语言:txt
复制
if i < 0:
代码语言:txt
复制
    return None
代码语言:txt
复制
root = TreeNode(prefix[0])
代码语言:txt
复制
root.left = prefix_to_inorder(prefix[1:i+1], inorder[i+1:])
代码语言:txt
复制
root.right = prefix_to_inorder(prefix[i+1:], inorder[i+1:])
代码语言:txt
复制
return root

def build_prefix_tree(inorder, postorder):

代码语言:txt
复制
if not inorder or not postorder:
代码语言:txt
复制
    return None
代码语言:txt
复制
root = TreeNode(postorder[-1])
代码语言:txt
复制
i = len(inorder)
代码语言:txt
复制
root.left = build_prefix_tree(inorder[:i], postorder[:i])
代码语言:txt
复制
root.right = build_prefix_tree(inorder[i+1:], postorder[i:-1])
代码语言:txt
复制
return root

def build_tree_from_inorder(inorder):

代码语言:txt
复制
if not inorder:
代码语言:txt
复制
    return None
代码语言:txt
复制
root = TreeNode(inorder[0])
代码语言:txt
复制
i = 1
代码语言:txt
复制
while i < len(inorder) and inorder[i] == inorder[0]:
代码语言:txt
复制
    i += 1
代码语言:txt
复制
root.left = build_tree_from_inorder(inorder[1:i])
代码语言:txt
复制
root.right = build_tree_from_inorder(inorder[i:])
代码语言:txt
复制
return root

def inorder_to_tree(inorder):

代码语言:txt
复制
if not inorder:
代码语言:txt
复制
    return None
代码语言:txt
复制
root = TreeNode(inorder[0])
代码语言:txt
复制
i = 1
代码语言:txt
复制
while i < len(inorder) and inorder[i] == inorder[0]:
代码语言:txt
复制
    i += 1
代码语言:txt
复制
root.left = inorder_to_tree(inorder[1:i])
代码语言:txt
复制
root.right = inorder_to_tree(inorder[i:])
代码语言:txt
复制
return root

def inorder_to_tree_and_postorder(inorder

页面内容是否对你有帮助?
有帮助
没帮助

相关·内容

  • 彻底用图解教会你——中缀表达式转后缀和前缀

    中缀表达式,大家最熟悉了。就是运算符在操作数中间。像这样: 1 + 2 * 3 + 4 它的特点是: 运算符和操作数必须依次间隔出现,不允许两个操作数中间没有运算符,也不允许两个运算符中间没有操作数。 备注:一元运算符等特殊情况除外。 如果要改变表达式的计算顺序,只有一种方法,加括号,像这样: (1 + 2) * (3 + 4) 括号的本质: 括号其实是提高了括号里面运算符的优先级,而且括号嵌套的层次越多,它里面的运算符的优先级提高的就越多。 中缀和括号的优点: 非常直观,特别适合人类理解。 中缀和括号的缺点: 不够纯粹,毕竟括号和普通运算符是不一样的。还有就是计算机无法直接计算。 于是一个波兰的数学家就想办法把括号去掉了,就是下面这个。 前缀表达式,运算符写在前面,操作数写在后面,像这样: * + 1 2 + 3 4 这就是上面那个带括号的对应的前缀形式,可以看到括号已经没有了。 它的特点是: 以运算符开头,以操作数结尾,除此之外没有什么特点,且一眼看上去根本看不出对错,多个运算符可以挨在一起,多个操作数也可以挨在一起。特别是初学者,一定要记住这些,不要受中缀的影响。 大家为了纪念这哥们儿,也称这种形式为“波兰式”。 不得不说,人类还是很善于思考的,既然运算符在操作数前面是可以的,那么倒过来是不是也可以啊? 后缀表达式,操作数写在前面,运算符写在后面,像这样: 1 2 + 3 4 + * 这就是上面那个带括号的对应的后缀形式,可以看到括号也已经没有了。 它的特点是: 以操作数开头,以运算符结尾,然后就和前缀是一样的,一眼看不出对错,运算符可以挨着,操作数可以挨着,这里再次提醒初学者,要记住这些特点。 由于这种形式和“波兰式”正好相反,因此也称为“逆波兰式”。 后缀式和前缀式的计算过程 表达式的计算要用到栈,所以先准备两个栈,一个用红色标记,一个用绿色标记。 后缀式的计算过程,先看动画,再看分步解析:

    03

    中缀表达式转换为后缀表达式(逆波兰表达式)并对其求值

    中缀表达式转后缀表达式思路: 1.初始化一个运算符栈s1和存储中间结果的List集合s2; 2.从左至右扫描中缀表达式(这里为了方便把中缀表达式字符串依次存放到数组中); 3.遇到操作数时,将其加到s2; 4.遇到运算符时,比较其与s1栈顶运算符的优先级: 4.1.若s1为空,或栈顶运算符为左括号“(”,则直接将此运算符入栈 4.2.若优先级比栈顶运算符优先级高,也将运算符压入s1; 4.3.否则,将s1栈顶的运算符弹出并加到s2中,再次回到4.1与s1中新的栈顶运算符相比较 5.遇到括号时: 5.1.若是左括号“(”,则直接压入s1; 5.2.若是右括号“)”,则依次弹出s1栈顶运算符并加入s2,直到遇左括号为止,此时将这一对括号丢弃; 6.重复2-5,直到表达式最右边 7.将s1中剩余的运算符依次弹出并加入到s2 8.依次输出s2中的元素,结果即为中缀表达式对应的后缀表达式。

    03

    栈在表达式求值中的应用——逆波兰表达式求值+中缀表达式转后缀表达式

    我们正常写的表达式,就比如题目中的这个:(2 + 1) * 3 这种写法叫做中缀算术表达式,即运算符写在操作数的中间,但是这种写法计算机是不能直接计算的,因为涉及运算符优先级的问题,比如1+2*3,应该先算*。 所以呢,这里就需要我们做一件事情,就是把它变成后缀表达式,其实就是根据优先级对表达式中的运算符排一个序,并且放到对应的操作数后面。 就比如题目中给的这个示例:((2 + 1) * 3)这个表达式对应的后缀表达式就是["2","1","+","3","*"](题中是把它放到一个字符串数组中了)。 即1和2先进行后面的+,得到的结果再和3进行后面的*,得到最终结果。这样就直接从前往后算,不用考虑优先级的问题了。

    01
    领券