1
已知一颗有 2011 2011 2011个结点的数,其叶结点个数为 116 116 116,求该树对应的二叉树中无右孩子的结点个数。
解答
这棵树非终端结点个数为 2011 − 116 = 1895 2011-116=1895 2011−116=1895个。注意到对于每一个非终端结点,其最右孩子的右兄弟指针为空(因为已经没有其他兄弟了)。但还需要注意不要漏掉了根节点,因此有 1895 + 1 = 1896 1895+1=1896 1895+1=1896个。
如果这一道题问到了森林,解法类似。只需森林里面最右一棵树根节点(相当于本题中树的根节点)的右指针为空。
除此之外,如果本题是选择题,也可以用特殊值法。构造一棵特殊的满足题目要求的树:除 116 116 116个叶结点外,其余结点均只有一个孩子。易得到最终的结果。
2
已知三叉树 T T T中 6 6 6个叶结点的权分别是 2 , 3 , 4 , 5 , 6 , 7 2, 3, 4, 5, 6, 7 2,3,4,5,6,7,