「扫盲」数据结构 - 二叉树入门

:fire: 什么是二叉树:grey_question:

有一个根节点 :red_circle: 向下扩展两个子节点 :red_circle: 两个子节点又可以向下扩展。类似于这样的结构成为二叉树

image-20200318164309773

上面这种就够就是二叉树,当然有二叉树就有三叉树、四叉树。

image-20200318164534883

树中相应节点的概念

image-20200318165011873
  • A 节点是 B 节点的【父节点
  • B 节点是 A 节点的【子节点
  • B、C、D 这三个节点的父亲节点是同一个节点,所以他们之间互称为【兄弟节点
  • E 节点没有父亲节点,所以我们把它称为【根节点
  • G、H、I、J、K、L 没有子节点,所以我们把它称为【叶子节点
  • 节点的高度:节点到叶子节点的最长路径
  • 节点的深度:根节点到这个节点所经历的节点个数
  • 节点的层数:节点的深度 + 1

二叉树的种类

在二叉树之上,具备各种各样的其他属性,就会衍生出其他的树结构。

  • 满二叉树

    image-20200318170240608

    叶子节点全都在最底层,除叶子节点外,每个节点都有两个子节点,这种二叉树叫做【满二叉树】。

  • 完全二叉树

    image-20200318170532465

    叶子节点都在最底下两层,最后一次的叶子节点都靠左排列,并且除了最后一层,其他层的节点个数都要达到最大,这种二叉树叫做【完全二叉树

  • 二分搜索树

    image-20200318171007366

    若任意节点的左子树不为空,则左子树上所有节点的值均小于它的根节点的值;

    若任意节点的右子树不为空,则右子树上所有节点的值均大于或等于它的根节点的值;

    任何左子树或右子树也都为二分搜索树。

  • image-20200318195545250

    堆就是用数组实现的二叉树,所以它没有使用父指针或子指针。堆根据堆属性来排序。

堆的常用方法

构建优先队列、支持堆排序、支持找出一个集合中最小值(或者最大值)

堆分为两种:最大堆和最小堆,两者的差别在于节点的排序方式。

在最大堆中,父节点的值每一个子节点的值都要大。在最小堆中,父节点的值比每一个子节点的值都要小。这就是所谓的“堆属性”,并且这个属性对堆中的每一个节点都成立。

  • AVL

  • 红黑树

  • 线段树

  • 字典树

  • 并查集

树的遍历

  • 前序 根左右

  • 中序 左根有

  • 后序 左右根

  • DFS 深度优先遍历

    代码模板(递归写法)

    visited = set() 
    
    def dfs(node, visited):
        if node in visited: # terminator
            # already visited 
            return 
    
        visited.add(node) 
    
        # process current node here. 
        ...
        for next_node in node.children(): 
            if next_node not in visited: 
                dfs(next_node, visited)

    非递归写法

    def DFS(self, tree): 
    
        if tree.root is None: 
            return [] 
    
        visited, stack = [], [tree.root]
    
        while stack: 
            node = stack.pop() 
            visited.add(node)
    
            process (node) 
            nodes = generate_related_nodes(node) 
            stack.push(nodes) 
    
        # other processing work 
        ...
  • BFS 广度优先遍历(层序遍历)

    代码模板

    def BFS(graph, start, end):
        visited = set()
        queue = [] 
        queue.append([start]) 
    
        while queue: 
            node = queue.pop() 
            visited.add(node)
    
            process(node) 
            nodes = generate_related_nodes(node) 
            queue.push(nodes)
    
        # other processing work 
        ...

开源项目推荐

SCHEDULE-BILIBILI

只有 Js 能干点啥,JS 和 Github Actions 实现哔哩哔哩每日自动签到、投币、领取奖励。🐄 🍺

IDEA-TopTips

IDEA 宇宙最强操作技巧,错误此项目 后悔一生。🐄 🍺

Python网络爬虫与推荐算法新闻推荐平台:网络爬虫:通过Python实现新浪新闻的爬取,可爬取新闻页面上的标题、文本、图片、视频链接(保留排版) 推荐算法:权重衰减+标签推荐+区域推荐+热点推荐.zip项目工程资源经过严格测试可直接运行成功且功能正常的情况才上传,可轻松复刻,拿到资料包后可轻松复现出一样的项目,本人系统开发经验充足(全领域),有任何使用问题欢迎随时与我联系,我会及时为您解惑,提供帮助。 【资源内容】:包含完整源码+工程文件+说明(如有)等。答辩评审平均分达到96分,放心下载使用!可轻松复现,设计报告也可借鉴此项目,该资源内项目代码都经过测试运行成功,功能ok的情况下才上传的。 【提供帮助】:有任何使用问题欢迎随时与我联系,我会及时解答解惑,提供帮助 【附带帮助】:若还需要相关开发工具、学习资料等,我会提供帮助,提供资料,鼓励学习进步 【项目价值】:可用在相关项目设计中,皆可应用在项目、毕业设计、课程设计、期末/期中/大作业、工程实训、大创等学科竞赛比赛、初期项目立项、学习/练手等方面,可借鉴此优质项目实现复刻,设计报告也可借鉴此项目,也可基于此项目来扩展开发出更多功能 下载后请首先打开README文件(如有),项目工程可直接复现复刻,如果基础还行,也可在此程序基础上进行修改,以实现其它功能。供开源学习/技术交流/学习参考,勿用于商业用途。质量优质,放心下载使用。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值