首页 > 其他分享 >关于二叉树,你应该了解这些。(二叉树的理论基础)

关于二叉树,你应该了解这些。(二叉树的理论基础)

时间:2022-11-17 20:36:48浏览次数:47  
标签:结点 遍历 TreeNode 理论 存储 了解 搜索 二叉树



推荐视频——关于二叉树,你该了解这些!| 二叉树理论基础一网打尽,二叉树的种类、二叉树的存储方式、二叉树节点定义、二叉树的遍历顺序_哔哩哔哩 (゜-゜)つロ 干杯~-bilibili

我的小站——半生瓜のblog(同步更新哦)


理论基础,这些都是我们平时刷题应该掌握的内容。

把基础打牢了,有了逻辑基础,学的才会更好一些。


二叉树的理论基础

  • ​​1.二叉树的种类​​
  • ​​1.满二叉树:​​
  • ​​2.完全二叉树​​
  • ​​3.二叉搜索树​​
  • ​​2.二叉树的存储方式​​
  • ​​1.顺序存储​​
  • ​​2.链式存储​​
  • ​​3.二叉树的遍历​​
  • ​​4.二叉树结点的定义​​

1.二叉树的种类

1.满二叉树:

  • 在一棵二叉树中,如果所有分支结点都存在左子树和右子树,并且所有叶子都在同一层上,这样的二叉树叫做满二叉树。
  • 结点数量2^k-1

2.完全二叉树

  • 除了底层以外,其它层都是满的,底层是从左到右连续的。

  • 这个是二叉树
  • 关于二叉树,你应该了解这些。(二叉树的理论基础)_数据结构

  • 这个就不是二叉树,底层不连续。
  • 关于二叉树,你应该了解这些。(二叉树的理论基础)_子树_02


满二叉树一定是一棵完全二叉树,但完全而二叉树不一定是满的。


3.二叉搜索树

  • 在它里面的结点顺序,左子树的所有结点都小于中间结点,右子树的所有结点都大于中间结点。
  • 关于二叉树,你应该了解这些。(二叉树的理论基础)_二叉树_03

  • 二叉搜索树对结点的布局是没有要求的,元素有顺序就可以。

  • 平衡二叉搜索树

    • 左子树和右子树的高度差不能超过1。
2.二叉树的存储方式

1.顺序存储

关于二叉树,你应该了解这些。(二叉树的理论基础)_结点_04

用这个字符数组来保存二叉树。

关于二叉树,你应该了解这些。(二叉树的理论基础)_结点_05

**2*i+1——左孩子,2 *i+2——右孩子。 **

2.链式存储

一般用的都是链式存储。

关于二叉树,你应该了解这些。(二叉树的理论基础)_二叉树_06

3.二叉树的遍历

扩展:

  • 深度优先搜索:一般都是用递归的方式来实现的,前序遍历,中序遍历,后序遍历,都是深度优先搜索。(迭代法也可以实现前中后序,非递归的方式。)
  • 广度优先搜索:一层一层的去遍历,或者是一圈一圈的去遍历。层序遍历就是广度优先搜索的一种。

关于二叉树,你应该了解这些。(二叉树的理论基础)_子树_07

前序遍历:**中左右。**5412678

中序遍历:左中右。4125768

后序遍历:左右中。1247865

4.二叉树结点的定义

将二叉树理解为一个链表就会简单很多。

struct TreeNode
{
int val;//放数值
TreeNode* left;
TreeNode* right;
//实现一个构造函数,在new一个结点的时候,方便对其进行初始化。
TreeNode(t):val:t,left(NULL),right(NULL);
}




标签:结点,遍历,TreeNode,理论,存储,了解,搜索,二叉树
From: https://blog.51cto.com/u_15333750/5866138

相关文章

  • 黏包现象、struct模块和解决黏包问题的流程、UDP协议、并发编程理论、多道程序设计技
    目录黏包现象二、struct模块及解决黏包问题的流程三、粘包代码实战UDP协议(了解)并发编程理论多道技术进程理论进程的并行与并发进程的三状态黏包现象什么是粘包1.服务......
  • 计算机网络——并发编程理论、多道技术、进程理论、进程的并行与并、进程的三状态
    计算机网络——并发编程理论、多道技术、进程理论、进程的并行与并、进程的三状态一、并发编程理论"""计算机中真正干活的是CPU"""操作系统发展史 1.穿孔卡片阶段......
  • 并发编程理论
    网络编程研究网络编程其实就是在研究计算机的底层原理计算机中CPU才是真正干活的人并发编程理论发展史:1.穿孔卡片一次只能给一个人使用电脑cpu利用率极低......
  • 并发编程理论
    操作系统发展史1.穿孔卡片阶段计算机很庞大,使用很麻烦,一次只能给一个人使用,期间很多时候计算机都不工作好处:程序员独占计算机,为所欲为 坏处:计算机利用率太低,浪费......
  • 并发编程理论之多道技术、进程
    并发编程理论之多道技术、进程操作系统的发展穿孔卡片1946年第一台计算机诞生--20世纪50年代中期,还未出现操作系统,计算机工作采用手工操作方式。程序员将对应用程序......
  • 黏包 struct模块 进程理论进程的并行与并发
    今日内容黏包现象1.服务端连续三次执行recv2.客户端连续三次执行send问题:服务端一次性接收到了客户端三次消息该现象称为"黏包现象"黏包现象产生的原因 1.不知道......
  • 利用数组构建二叉树(随笔)
    做leetcode的时候,看到示例,突然想自己构建一颗树。。随即自己写了尝试写了一个方法(比较随意)测试用例://example-1[2,1,3]//example-2[2,null,3]//example-3[5,3......
  • .NET深入了解哈希表和Dictionary
    引子问题:给定一串数字{1,2,5,7,15,24,33,52},如何在时间复杂度为O(1)下,对数据进行CURD?数组:我创建一个Length为53的数组,将元素插入相同下标处,是不是就可以实现查找复杂......
  • 数据结构基础—树与二叉树(1)
    数据结构基础—树和二叉树一、树、二叉树类型定义1.树的定义a.定义树是一种非线性结构,是具有相同特征的数据元素的集合(同质/类)数据对象D:D是具有相同特征的数据元......
  • 你想了解的都在这!
    一:你可以在这些网站上找到我洛谷:用户昵称:kkksc006用户编号:768170用户类型:普通用户注册时间:2022-08-07VirtualJudge:用户名:AQ_用户昵称:小行星撞地球OpenJudge......