数据结构之二叉树(4)

(注:本文所示代码均为C++)

一.二叉树选择题

根据二叉树的性质,完成以下选择题:
 
(1)第一组
 
某二叉树共有 399 个结点,其中有 199 个度为 2 的结点,则该二叉树中的叶子结点数为( )
A 不存在这样的二叉树
B 200
C 198
D 199
 
在具有 2n 个结点的完全二叉树中,叶子结点个数为( )
A n
B n+1
C n-1
D n/2
 
一棵完全二叉树的结点数位为 531 个,那么这棵树的高度为( )
A 11
B 10
C 8
D 12
 
一个具有 767 个结点的完全二叉树,其叶子结点个数为()
A 383
B 384
C 385
D 386
 
(2)链式二叉树遍历选择题
 
某完全二叉树按层次输出(同一层从左到右)的序列为 ABCDEFGH 。该完全二叉树的前序序列为( )
A ABDHECFG
B ABCDEFGH
C HDBEAFCG
D HDEBFGCA
 
二叉树的先序遍历和中序遍历如下: 先序遍历: EFHIGJK;中序遍历: HFI EJKG, 则二叉树根结点为()
A E
B F
C G
D H
 
设一课二叉树的中序遍历序列: badce,后序遍历序列: bdeca,则二叉树前序遍历序列为____。
A adbce
B decab
C debac
D abcde
 
某二叉树的后序遍历序列与中序遍历序列相同,均为 ABCDEF ,则按层次输出(同一层从左到右)的序列为
A FEDCBA
B CBAFED根据二叉树的性质,完成以下选择题:

 

选择题答案

 二.二叉树编程题

1.单值二叉树

 LeetCode 965题聚焦“单值二叉树”。题目要求判断给定二叉树的每个节点值是否相同,若是则为单值二叉树,需返回 true ,否则返回 false  。示例展示了一棵节点值均为1的二叉树。

 

右侧代码中, Solution 类的 isUnivalTree 函数展开判断逻辑。首先,若根节点为空,按照定义它是单值二叉树(空树特殊情况),直接返回 true  。接着,检查根节点的左子节点(若存在),一旦其值与根节点值不同,说明树不是单值的,返回 false  ;对右子节点也执行相同检查。最后,通过递归方式,继续检查左子树和右子树是否为单值二叉树,只有左右子树都满足单值条件,整棵树才是单值二叉树,此时返回 true  ,全面且严谨地实现了题目要求。

 

2.相同的树

 LeetCode 100题“相同的树”,旨在判断给定的两棵二叉树在结构和节点值上是否完全一致。解题的核心在于递归地比较两棵树的节点。

 代码中, isSameTree 函数先处理边界情况:若两棵树的当前节点都为空,说明这部分结构相同,返回 true ;若其中一棵为空而另一棵不为空,结构不一致,返回 false ;若节点值不同,也返回 false 。然后,通过递归调用自身分别检查两棵树的左子树和右子树是否相同,只有当左右子树都相同时,两棵树才是完全相同的,以此实现对两棵二叉树是否相同的准确判断。

 

3.另一棵子树

 LeetCode 572题“另一棵树的子树”,任务是判断二叉树 root 中是否存在与 subRoot 结构和节点值都相同的子树。解题关键在于比较两棵树的结构和节点值。

 

代码中, isSameTree 函数用于判断两棵树是否完全相同。先处理边界情况,若两棵树都为空,返回 true ;若一棵为空另一棵不为空,返回 false ;若根节点值不同,也返回 false ;然后递归检查左右子树。 isSubtree 函数则以 root 树的每个节点为起点,调用 isSameTree 函数判断是否存在与 subRoot 相同的子树,通过递归遍历 root 树的左右子树来完成整体判断,逻辑清晰地解决了子树判断问题。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值