博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
二叉树实现按层 s型打印
阅读量:6689 次
发布时间:2019-06-25

本文共 2115 字,大约阅读时间需要 7 分钟。

题目阐释:

s型打印,重要的是将binary—tree 逐层遍历,获取每层的node。

思路:

将树的遍历转化为 压栈出栈。 每次将列表内的node全部出栈,获取子元素,然后全部再入栈。 如此反复迭代

应用:

当树有层次信息时候,可以如此操作。

代码如下:

class Node(object):    def __init__(self, val):        self.left_node = None        self.right_node = None        self.value = valclass MakeNode(object):    def __init__(self):        pass    def make_series(self, root_val, value_list_in):        root = Node(root_val)        # cur_node=root        cur_nodes = list()        cur_nodes.append(root)        while cur_nodes:            nodes_iters = list()            while cur_nodes:                cur_node = cur_nodes.pop(0)                nodes_iters.append(cur_node)            for node_iter in nodes_iters:                if value_list_in:                    values_iter = value_list_in.pop(0)                    if values_iter[0]:                        node = Node(values_iter[0])                        node_iter.left_node = node                        cur_nodes.append(node)                    if values_iter[1]:                        node = Node(values_iter[1])                        node_iter.right_node = node                        cur_nodes.append(node)        # print(root)        return rootclass BinaryTree(object):    def __init__(self):        pass    def stack(self,root):        nodes=[root]        flag=0        while nodes:            nodes_tmp=list()            while nodes:                nodes_tmp.append(nodes.pop(0))            # print('nodes_tmp==>',nodes_tmp)            if flag%2==0:                nodes_print=nodes_tmp            else:                nodes_print=nodes_tmp[::-1]            for val_node in nodes_print:                if val_node:                    print(val_node.value)            for node_iter in nodes_tmp:                if node_iter:                    # print(node_iter.value)                    nodes.extend([node_iter.left_node,node_iter.right_node])            flag+=1if __name__ == '__main__':    root = 1    values = [[2,3], [4, 5], [6, 7], [8, 9], [10, 11], [12, None], [None, 13]]    mn = MakeNode()    root=mn.make_series(root, values)    bt=BinaryTree()    bt.stack(root)

转载地址:http://cbeao.baihongyu.com/

你可能感兴趣的文章
企业级 SpringBoot 教程 (二十)处理表单提交
查看>>
解决->Word无法创建工作文件,请检查临时环境变量
查看>>
面包屑导航
查看>>
正则表达式
查看>>
CentOS6.5固定IP方式上网(NAT)
查看>>
jboss信息安全
查看>>
[DP][二分]JZOJ 3463 军训
查看>>
SQL语言基础
查看>>
跟左神学算法10 经典算法 - 递归与动态规划
查看>>
888. Uncommon Words from Two Sentences
查看>>
查看最新的Google地址
查看>>
数值与字符串的转换
查看>>
正则表达式基础总结
查看>>
oalTouch (OpenAL的一个应用)
查看>>
编译发布版本的时候移除NSLog输出的方法
查看>>
黄聪:VS2017调试时提示“运行时无法计算表达式的值”
查看>>
黄聪:iis7.5 偶尔出现500服务器错误-内部服力器错误
查看>>
爬虫库之BeautifulSoup学习(四)
查看>>
Windows中git使用教程
查看>>
网页音乐制作器(网页钢琴)-- MusicMaker
查看>>