标题:求优化——二叉树
只看楼主
Ⅳ飒
Rank: 1
等 级:新手上路
帖 子:12
专家分:7
注 册:2019-5-4
结帖率:0
 问题点数:0 回复次数:0 
求优化——二叉树
题目:已知某二叉树中序遍历结果为cbedahgijf、后序遍历结果为cedbhjigfa,编程实现二叉树的二叉链表示法,并输出先序遍历结果。

class BTNode:
    def __init__(self,data=None,lchild=None,rchild=None):
        self.data=data
        self.lchild=lchild
        self.rchild=rchild
        

def CreateBTNode(post,im,length):
    if (length<=0):
        return None
    s=BTNode(post[-1])   
    k=-1   
    for p in im:
        k+=1
        if p==s.data:
            break
        
    s.lchild=CreateBTNode(post[0:k],im[0:k],k)
    s.rchild=CreateBTNode(post[k:length-1],im[k+1:],length-k-1)
    return s

def predis(s):
    if s!=None:
        print(s.data,end="")
        predis(s.lchild)
        predis(s.rchild)
     
   
if __name__=='__main__':
    im=input('请输入中序遍历结果:')
    post=input('请输入后序遍历结果:')
    length=len(im)   
    predis(CreateBTNode(post,im,length))
    print("")
搜索更多相关主题的帖子: 二叉树 遍历 结果 data post 
2019-05-05 15:55



参与讨论请移步原网站贴子:https://bbs.bccn.net/thread-494559-1-1.html




关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.186382 second(s), 7 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved