二叉树的逻辑结构

二叉树的定义:
二叉树是n(n≥0)个结点的有限集合,该集合或者为空集(称为空二叉树),或者由一个根结点和两棵互不相交的、分别称为根结点的左子树和右子树的二叉树组成。
二叉树的特点:
⑴ 每个结点最多有两棵子树;
⑵ 二叉树是有序的,其次序不能任意颠倒。
注意:二叉树和树是两种树结构。
特殊二叉树:
一、斜树
1 .所有结点都只有左子树的二叉树称为左斜树;
2 .所有结点都只有右子树的二叉树称为右斜树;
3.左斜树和右斜树统称为斜树。
二、满二叉树
在一棵二叉树中,如果所有分支结点都存在左子树和右子树,并且所有叶子都在同一层上。
特点:
叶子只能出现在最下一层;
只有度为0和度为2的结点。
满二叉树在同样深度的二叉树中结点个数最多
满二叉树在同样深度的二叉树中叶子结点个数最多
三、完全二叉树
对一棵具有n个结点的二叉树按层序编号,如果编号为i(1≤i≤n)的结点与同样深度的满二叉树中编号为i的结点在二叉树中的位置完全相同。
在满二叉树中,从最后一个结点开始,连续去掉任意个结点,即是一棵完全二叉树。
特点:

  1. 叶子结点只能出现在最下两层,且最下层的叶子结点都集中在二叉树的左部;
  2. 完全二叉树中如果有度为1的结点,只可能有一个,且该结点只有左孩子。
  3. 深度为k的完全二叉树在k-1层上一定是满二叉树。

二叉树的基本性质:
性质1 二叉树的第i层上最多有2i-1个结点(i≥1)。
性质2 一棵深度为k的二叉树中,最多有2k-1个结点,最少有k个结点。
性质3 在一棵二叉树中,如果叶子结点数为n0,度为2的结点数为n2,则有: n0=n2+1。
性质4 具有n个结点的完全二叉树的深度为 log2n +1。
性质5 对一棵具有n个结点的完全二叉树中从1开始按层序编号,则对于任意的序号为i(1≤i≤n)的结点(简称为结点i),有:
(1)如果i>1,
则结点i的双亲结点的序号为 i/2;如果i=1,
则结点i是根结点,无双亲结点。
(2)如果2i≤n,
则结点i的左孩子的序号为2i;
如果2i>n,则结点i无左孩子。
(3)如果2i+1≤n,
则结点i的右孩子的序号为2i+1;如果2i+1>n,则结点 i无右孩子。
补充:
对一棵具有n个结点的完全二叉树中从1开始按层序编号,则
结点i的双亲结点为 i/2;
结点i的左孩子为2i;
结点i的右孩子为2i+1。

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL是一个关系型数据库管理系统,它主要用于存储和管理结构化数据。MySQL本身并不提供构造二叉树的功能,但可以通过使用递归查询和存储过程来实现二叉树的构造和操作。 要在MySQL中构造二叉树,可以使用以下步骤: 1. 创建一个包含节点信息的表,例如`tree_node`表,该表至少应包含以下列: - `id`:节点的唯一标识符 - `value`:节点的值 - `left_child_id`:左子节点的id - `right_child_id`:右子节点的id 2. 插入根节点: ```sql INSERT INTO tree_node (id, value, left_child_id, right_child_id) VALUES (1, 'root', NULL, NULL); ``` 3. 插入其他节点: ```sql INSERT INTO tree_node (id, value, left_child_id, right_child_id) VALUES (2, 'left_child', NULL, NULL); INSERT INTO tree_node (id, value, left_child_id, right_child_id) VALUES (3, 'right_child', NULL, NULL); ``` 4. 更新父节点的子节点信息: ```sql UPDATE tree_node SET left_child_id = 2 WHERE id = 1; UPDATE tree_node SET right_child_id = 3 WHERE id = 1; ``` 5. 递归插入子节点: ```sql DELIMITER // CREATE PROCEDURE insert_child_node(IN parent_id INT, IN child_id INT, IN is_left_child BOOLEAN) BEGIN DECLARE child_value VARCHAR(255); SET child_value = (SELECT value FROM tree_node WHERE id = child_id); IF is_left_child THEN UPDATE tree_node SET left_child_id = child_id WHERE id = parent_id; ELSE UPDATE tree_node SET right_child_id = child_id WHERE id = parent_id; END IF; INSERT INTO tree_node (id, value, left_child_id, right_child_id) VALUES (child_id, child_value, NULL, NULL); END // DELIMITER ; CALL insert_child_node(2, 4, TRUE); -- 在左子节点下插入一个节点 CALL insert_child_node(2, 5, FALSE); -- 在左子节点下插入另一个节点 ``` 通过以上步骤,你可以在MySQL中构造一个简单的二叉树。当然,你可以根据实际需求扩展表结构和操作逻辑

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值