解题思路:

注意事项:

参考代码:

# 定义树节点的数据结构

class TreeNode:

    def __init__(self, val):

        self.val = val

        self.left = None

        self.right = None


# 构建二叉树

def buildTree(inorder, levelorder):

    if not inorder or not levelorder:

        return None

    

    # 获取根节点的值

    root_val = levelorder[0]

    root = TreeNode(root_val)

    

    # 在中序遍历序列中找到根节点的位置

    root_idx = inorder.index(root_val)

    

    # 将中序遍历序列分为左子树和右子树

    inorder_left = inorder[:root_idx]

    inorder_right = inorder[root_idx + 1:]

    

    # 在按层遍历序列中找到左子树和右子树的节点值

    levelorder_left = [val for val in levelorder if val in inorder_left]

    levelorder_right = [val for val in levelorder if val in inorder_right]

    

    # 递归构建左子树和右子树

    root.left = buildTree(inorder_left, levelorder_left)

    root.right = buildTree(inorder_right, levelorder_right)

    

    return root


# 先序遍历二叉树

def preorderTraversal(root):

    if not root:

        return []

    

    result = []

    stack = [root]

    

    while stack:

        node = stack.pop()

        result.append(node.val)

        

        if node.right:

            stack.append(node.right)

        if node.left:

            stack.append(node.left)

    

    return result


# 主函数

def main():

    inorder = input().strip()  # 中序遍历序列

    levelorder = input().strip()  # 按层遍历序列

    

    # 构建二叉树

    root = buildTree(inorder, levelorder)

    

    # 先序遍历二叉树

    preorder = preorderTraversal(root)

    

    # 输出先序序列

    print(''.join(preorder))


# 调用主函数

main()


点赞(0)
 

0.0分

1 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论