完全二叉树叶子结点的算法

转自:http://blog.sina.com.cn/s/blog_477c8fd70100ggub.html

noip中经常会遇到求完全二叉树叶子结点的问题,比如第十一届全国青少年信息学奥林匹克联赛初赛试题的第四题:完全二叉树的结点个数为4 *N+ 3 ,则它的叶结点个数为()。

A. 2 *N B. 2 *N- 1 C. 2 *N+ 1 D. 2 *N- 2 E. 2 *N+ 2


  结论:如果一棵具有n个结点的深度为k的完全二叉树,其叶子结点数和总结点数有这样的关系:n(叶子)=(n总+1)/2,由上所知,我们可以判断这道题的 叶结点个数为(4 *N+ 3+1)/2=2 *N+ 2.

 

14(第十二届).高度为n的均衡的二叉树是指:如果去掉叶结点及相应的树枝,它应该是高度为n-1的满二叉树。在这里,树高等于叶结点的最大深度,根结点的深度为0,如果某个均衡的二叉树共有2381个结点,则该树的树高为()。
A. 10 B. 11 C. 12 D. 13
均衡二叉树就是:任意两个度不为2的节点的深度之差不大于1
例如:
           1
          / \
        2     3
         \    /
          4  5
是均衡二叉树

          1
          / \
        2     3
         \   / \
          4 5   6
                 /
                7
就不是,2和7的深度差2.
因为2^11 = 2048;所以一颗满二叉树从深度为0(根节点)到深度10的总节点数是2047,剩下2381-2047 = 334个节点,这剩下的节点的深度都是11。
所以答案为B


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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值