python 二叉树中序遍历[通俗易懂]

python 二叉树中序遍历[通俗易懂]根据树的递归性,使用List存储下面这棵树,然后编写函数对其进行中序遍历,最后删除节点D。递归实现中序遍历列表存储的二叉树python列表模拟二叉树存放,列表=[[左子树],根节点,[右子树]]列表里有列表,列表里又有列表。之前用treelist[1]==[]判断return,会有超限的问题。后来想了想,用列表长度判断是否return似乎是个不错的选择。d…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

根据树的递归性,使用List存储下面这棵树,然后编写函数对其进行中序遍历。

中序遍历DBEAC

递归实现中序遍历列表存储的二叉树

python列表模拟二叉树存放,列表 = [ [左子树] , 根节点 , [右子树] ]
列表里有列表,列表里又有列表。
之前用 treelist[1] == [ ]判断return,会有超限的问题。
后来想了想,用列表长度判断是否return似乎是个不错的选择。

def Traversal(treelist):        
    if len(treelist) == 1:
        print(treelist[0], end='')
        return
    elif len(treelist) == 2:
        if type(treelist[0]) == list:
            Traversal(treelist[0])
            print(treelist[1], end='') 
        else:
            print(treelist[0], end='')   
            Traversal(treelist[1])
              
    else:
        Traversal(treelist[0])
        print(treelist[1], end='')
        Traversal(treelist[2])
tree = [ [ [ 'D' ], 'B', [ 'E' ] ], 'A', [ 'C' ] ]
print('中序遍历二叉树:')
Traversal(tree)

中序遍历二叉树:
DBEAC

tree = [ [ [['F'], 'C', [ ['I'], 'G']], 'B' ], 'A', [ 'D', ['E', ['H'] ] ] ]
Traversal(tree)

FCIGBADEH

?

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/194143.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • jquery验证插件对表格数据的验_js与jquery的区别

    jquery验证插件对表格数据的验_js与jquery的区别①:引入js类库以及样式

    2022年9月26日
    4
  • 计算机考研数据库题库及答案_数据结构历年考研真题

    计算机考研数据库题库及答案_数据结构历年考研真题在数据库的三级模式结构中,描述数据库中全体数据的全局逻辑结构和特征的是()。A.充分必要条件B.必要条件C.充分条件D.既不充分也不必要条件。A.需求分析阶段B.概念设计阶段C.逻辑设计阶段D.物理设计阶段。在关系模式R(U,F)中,Y∈XF+是X→Y是否成立的()。A.数据库系统B.文件系统C.人工管理D.数据项管理。A.网络系统B.数据库系统C.操作系统D.数据库。A.外模式B.内模式C.存储模式D.模式。…

    2025年7月17日
    4
  • string 保留小数点后两位(js中保留小数点后两位)

    js保留小数点后N位的方法介绍利用toFixed函数代码如下复制代码document.write(“JS保留两位小数例子”);vara=2.1512131231231321;document.write(“原来的值:”+a+””);document.write(“两位小数点:”+a.toFixed(2)+”四位小数点”+a.toFixed(4));四舍五入的转换函数,如下:代码如下复制代码f…

    2022年4月13日
    387
  • Eurake分区理解

    Eurake分区理解Eurake分区理解大型项目如果存在多个机房,例如北京机房,上海机房,杭州机房等,上千个服务注册在Eurake上面,我们的事例也分别部署在各个区域。这时候,由于机房存在不同的区域,北京的一个服务如果调用上海的一个服务,就可能发生延迟,服务的响应速度也会慢很多,这时候,我们可能期望,北京的服务生产者调用北京的服务消费着,这该怎么去操作?Eurake其实有个分区功能,什么是分区,就是北京有一个注册…

    2022年6月12日
    39
  • bootstraptable之uniqueId

    bootstraptable之uniqueId如何设置每行唯一的标识符uniqueId$(‘#dataTable’).bootstrapTable(‘destroy’).bootstrapTable({columns:[{field:’OrganizeID’,title:’部门编号’,…

    2025年7月29日
    5
  • 时间轮详解

    时间轮详解转载自:https://blog.csdn.net/paxhujing/article/details/52066620问题引入:游戏里面每个Player身上有很多buffs,在每一个tick(最小时间段)都要去检查buff里面的每一个buff是不是过期,产生的效果如何,造成在每个tick里面都去遍历一个长list,明显很不好。怎么优化?1.原始模型:buff的状态在每一个tick里面都要更新!可…

    2022年10月1日
    6

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号