二叉树的深度优先遍历与广度优先遍历

简介: 先说说为什么要遍历,二叉树不是已经排好序了么?如果大于当前节点值,搜索右子树,小于当前值,继续搜索左子树。参考两个sql:select id,name,grade from student where id=1select id,name,grade from student where name='李四'按id查找,id是主键,已经创建索引,用二叉树存储,id就是二叉树节点的key,可以按照二分查找法搜索。

先说说为什么要遍历,二叉树不是已经排好序了么?如果大于当前节点值,搜索右子树,小于当前值,继续搜索左子树。
参考两个sql:
select id,name,grade from student where id=1
select id,name,grade from student where name='李四'

  • 按id查找,id是主键,已经创建索引,用二叉树存储,id就是二叉树节点的key,可以按照二分查找法搜索。
  • 按name搜索,只能采用遍历的方法,必须保证检查到树上的每一个节点,不能有遗漏。

数据库创建索引,可以加快搜索速度,但要维护额外空间。

深度优先遍历

先遍历子节点,再遍历兄弟节点。
从根节点开始递归,如果存在子节点,继续遍历子节点。

    def traverse_d(self):
        self._traverse_d(self.root)
        
    ##深度优先遍历
    def _traverse_d(self,node):
        if(node == None):
            return
        self._traverse_d(node.lnode)
        self._traverse_d(node.rnode)
        print("key:%d==>value:%d"% (node.key,node.value))

广度优先遍历

先遍历兄弟节点,在遍历子节点。
采用队列实现,出队时添加子节点。

    def traverse_w(self):
        self._traverse_w(self.root)
    ## 广度优先遍历
    def _traverse_w(self,node):
        q = Queue()
        q.put(node)
        while(not q.empty()):
            node = q.get()
            if(node.lnode!=None):
                q.put(node.lnode)
            if(node.rnode!=None):
                q.put(node.rnode)
            print("key:%d==>value:%d"% (node.key,node.value))

总结:

以作者的自身经历,二叉树的深度遍历比较好记,总是忘如何实现广度优先,后来记住一个诀窍,广度优先要有一个队列,就记住了。放个图,加深一下记忆。


队列
目录
相关文章
Ubuntu20.04实时显示CPU、内存、网速
Ubuntu20.04实时显示CPU、内存、网速
1528 0
Ubuntu20.04实时显示CPU、内存、网速
|
监控 安全 网络安全
当用户需求不详细时,如何有效应对
当用户需求不详细时,如何有效应对
473 0
|
10月前
|
缓存 前端开发 JavaScript
前端开发的必修课:如何让你的网页在弱网环境下依然流畅运行?
【10月更文挑战第30天】随着移动互联网的普及,弱网环境下的网页性能优化变得尤为重要。本文详细介绍了如何通过了解网络状况、优化资源加载、减少HTTP请求、调整弱网参数和代码优化等方法,提升网页在弱网环境下的加载速度和流畅性,从而改善用户体验。
556 4
|
8月前
|
机器学习/深度学习 弹性计算 人工智能
阿里云服务器ECS架构区别及选择参考:X86计算、ARM计算等架构介绍
在我们选购阿里云服务器的时候,云服务器架构有X86计算、ARM计算、GPU/FPGA/ASIC、弹性裸金属服务器、高性能计算可选,有的用户并不清楚他们之间有何区别,本文主要简单介绍下这些架构各自的主要性能及适用场景,以便大家了解不同类型的架构有何不同,主要特点及适用场景有哪些。
1186 10
|
人工智能 自然语言处理 算法
魔搭进校园 | AI赋能大学计划:AI大模型技术与产业趋势高校行·西安交通大学站成功举办
2024年1月10日,西安交通大学兴庆校区教2-1400丝路大礼堂,一场别开生面的AI技术交流讲座在此拉开帷幕。
|
Unix Linux Shell
《Linux/UNIX OpenLDAP实战指南》——2.7 OpenLDAP用户以及与用户组相关的配置
添加用户和用户组的方式有两种。一种是将系统用户通过migrationtools工具生成LDIF文件并结合ldapadd命令导入OpenLDAP目录树中,生成OpenLDAP用户。另一种通过自定义LDIF文件并通过OpenLDAP命令进行添加或者修改操作。
4047 0
|
Linux
3.10 Linux创建目录(mkdir命令)
mkdir 命令,是 make directories 的缩写,用于创建新目录,此命令所有用户都可以使用。
297 0
3.10 Linux创建目录(mkdir命令)
反转链表.leetcode206 《数据结构入门到精通N2》
反转链表.leetcode206 《数据结构入门到精通N2》
反转链表.leetcode206 《数据结构入门到精通N2》