数据结构期末复习:第五章-树与二叉树

翻大水嘤嘤嘤~学了之后隔了好久才做题感觉自己忘光了。
在这里插入图片描述

知识点

  • 中根遍历(非递归)
    先遇到的根不能访问,后遇到的先访问——栈来实现。
    在这里插入图片描述
  • 二叉树层次遍历(书上没有标程,队列实现)
    在这里插入图片描述
  • 构造二叉树
    在这里插入图片描述
  • 复制二叉树
    在这里插入图片描述
  • 深度(左右中更深的那个+1)
    在这里插入图片描述为什么要+1呢?举个栗子——
    在这里插入图片描述这里整棵树的深度等于以b为根的树和以f为根的树的深度更大者+1,没毛病。
  • 结点总数 VS 叶子结点总数
    在这里插入图片描述
  • 线索二叉树
    若左孩子空:左孩子指针域指向前驱;
    若右孩子空:右孩子指针域指向后继。
rtagltag
0:指向右孩子0:指向左孩子
1:指向后继1:指向前驱

在这里插入图片描述
在这里插入图片描述
后序自行脑补。

加强版线索二叉树:
在这里插入图片描述
这样就方便一些,让第一个结点的前驱和最后一个结点的后继不再悬空,而是指向头结点,头结点的左孩子域指针指向根结点,右孩子指针域指向最后一个结点,从而达到循环访问的目的。

  • 二叉树和树的存储结构
二叉树
顺序存储结构双亲表示法(连续单元)
链式存储结构(二/三叉链表)孩子表示法(邻接链表)
孩子兄弟表示法(二叉链表)
  • 树与二叉树的转换
    由于二者都可以用二叉链表来表示,故可以以之为中介,形成转换。
    给定一棵树,可以找到唯一与之对应的二叉树。
    在这里插入图片描述

树->二叉树:兄弟相连留长子
在这里插入图片描述
二叉树->树:左孩右右连双亲
在这里插入图片描述

森林->二叉树:树变二叉根相连
在这里插入图片描述

二叉树->森林
在这里插入图片描述

  • 树和森林的遍历
森林
先根先根
后根中根
层次

为什么森林有中根但是树没有呢?
树可能有若干子树,中根的话不知根排在哪里。
但是森林可分为三部分,如果按照123就是先根,如果按照213就是中根。没有后根,因为3必须放在最后(递归定义)
在这里插入图片描述

错题

一、

孩子兄弟表示法【树的存储结构】,又称二叉树表示法,又称二叉链表表示法,即以二叉链表作为树的存储结构。
在这里插入图片描述

在这里插入图片描述
这里把“二叉链表存储”和“线索二叉树”搞混,”根结点“和”头结点“不分。你不掉坑谁掉坑?还要注意,这里是用二叉链表存储树,如果是二叉树的链式存储,那么右指针当然指向右孩子。
但这里存的是树,也就是孩子兄弟表示法,所以右指针指向兄弟,左指针指向第一个孩子,但是根结点没有兄弟,所以为空。

二、
在这里插入图片描述
没发现A和B都可以吗???那就再看看呗,总不可能多选?再看都不看一眼~你不错谁错!

三、
在这里插入图片描述
只因为在人群中多看了你一眼~于是我错了。
心想:叶结点是不是更准确呢?于是就错了。
可能不是叶结点噢!
在这里插入图片描述四、
还在通过臆想判断完全二叉树最多和最少的结点吗?完全没必要。
在这里插入图片描述

节点数=分支数+1。
设度为1的节点n1个,度为2的节点为n2个,题设知道度为0的节点有124
124+n1+n2=n1+2*n2+1 n2=123 。
完全二叉树中,度为1的节点只能是1或者0个,此处取1。
所以总共最多248个节点 。
在这里插入图片描述同理。

今晚就不做书上的题了,明天做了再更,睡了睡了,额头长痘痘了,千年难遇啊~快点消失!哈雅酷。
感觉今晚干货满满~加油!(ง •_•)ง
在这里插入图片描述

在这里插入图片描述

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值