| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 1302 人关注过本帖
标题:求优化——二叉树
只看楼主 加入收藏
Ⅳ飒
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
快速回复:求优化——二叉树
数据加载中...
 
   



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

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