前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >关于二叉树,你应该了解这些。(二叉树的理论基础)

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

作者头像
半生瓜的blog
发布2023-05-12 21:12:13
1240
发布2023-05-12 21:12:13
举报
文章被收录于专栏:半生瓜のblog半生瓜のblog

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


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

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


1.二叉树的种类

1.满二叉树:

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

2.完全二叉树

  • 除了底层以外,其它层都是满的,底层是从左到右连续的。
  • 这个是二叉树
在这里插入图片描述
在这里插入图片描述
  • 这个就不是二叉树,底层不连续。
在这里插入图片描述
在这里插入图片描述

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


3.二叉搜索树

  • 在它里面的结点顺序,左子树的所有结点都小于中间结点,右子树的所有结点都大于中间结点。
在这里插入图片描述
在这里插入图片描述
  • 二叉搜索树对结点的布局是没有要求的,元素有顺序就可以。
  • 平衡二叉搜索树
    • 左子树和右子树的高度差不能超过1。

2.二叉树的存储方式

1.顺序存储

在这里插入图片描述
在这里插入图片描述

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

在这里插入图片描述
在这里插入图片描述

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

2.链式存储

一般用的都是链式存储。

在这里插入图片描述
在这里插入图片描述

3.二叉树的遍历


扩展:

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

在这里插入图片描述
在这里插入图片描述

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

中序遍历:左中右。4125768

后序遍历:左右中。1247865

4.二叉树结点的定义

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

代码语言:javascript
复制
struct TreeNode
{
   int val;//放数值
   TreeNode* left;
   TreeNode* right;
    //实现一个构造函数,在new一个结点的时候,方便对其进行初始化。
   TreeNode(t):val:t,left(NULL),right(NULL);	
}
本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2021-04-29,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
目录
  • 1.二叉树的种类
    • 1.满二叉树:
      • 2.完全二叉树
        • 3.二叉搜索树
        • 2.二叉树的存储方式
          • 1.顺序存储
            • 2.链式存储
            • 3.二叉树的遍历
            • 4.二叉树结点的定义
            相关产品与服务
            对象存储
            对象存储(Cloud Object Storage,COS)是由腾讯云推出的无目录层次结构、无数据格式限制,可容纳海量数据且支持 HTTP/HTTPS 协议访问的分布式存储服务。腾讯云 COS 的存储桶空间无容量上限,无需分区管理,适用于 CDN 数据分发、数据万象处理或大数据计算与分析的数据湖等多种场景。
            领券
            问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档