栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > Python

二叉树的应用(解析树,及树的的前序,中序,后序遍历)

Python 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

二叉树的应用(解析树,及树的的前序,中序,后序遍历)

1.解析树
1.1解析树构建器

我们的目标是构建一个如上图所示的二叉树实现的方法如下

from 数据结构与算法.栈.Queue import Stack
from 数据结构与算法.树.二叉树.二叉树 import BinaryTree


def buildParesTree(fpexp):
    fplist=fpexp.split()
    pStack=Stack()
    eTree=BinaryTree('')
    pStack.push(eTree)
    currentTree=eTree
    for i in fplist:
        if i=='(':
            currentTree.insertLeft('')
            pStack.push(currentTree)
            currentTree=currentTree.getLeftChild()
        elif i not in '+-*/':
            currentTree.setRootVal(eval(i))
            parent=pStack.pop()
            currentTree=parent
        elif i in '+-*/':
            currentTree.setRootVal(i)
            currentTree.insertRight('')
            pStack.push(currentTree)
            currentTree=currentTree.getRightChild()
        elif i==')':
            currentTree=pStack.pop()
        else:
            raise ValueError('Unknown Operator'+i)

    return eTree

三种遍历方法代码如下:

# 前序遍历算法
print('前序遍历算法')
def preorder(tree):
    if tree:
        print(tree.getRootVal())
        preorder(tree.getLeftChild())
        preorder(tree.getRightChild())
tree=buildParesTree('( 3 + ( 4 * 5 ) )')
preorder(tree)

# 后序遍历算法
print('后序遍历算法')
def postorder(tree):
    if tree!=None:
        postorder(tree.getLeftChild())
        postorder(tree.getRightChild())
        print(tree.getRootVal())
postorder(tree)

# 中序遍历函数
print('中序遍历函数')

def inorder(tree):
    if tree!=None:
        inorder(tree.getLeftChild())
        print(tree.getRootVal())
        inorder(tree.getRightChild())

inorder(tree)


转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/755347.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号