二叉树的父子节点位置关系

最近在看一个堆排序的时候,发现其中一行代码涉及到二叉树的位置关系 

    一个节点的左节点是其父节点下标的2k+1,右节点是其父节点下标的2K+2。

由于很久没复习过数据结构,突然很好奇这个结论的证明(虽然以前学习时已经证明过),然后写一份博客再加深一下。毕竟这个技术不用就很容易忘记。

大家都知道二叉树一个节点有2个子节点,右节点和左节点。因此,可以将二叉树每一层的数量看做一个公比为2的等比数列。如 第一层 也就是根节点的数量是2^0=1,第二层2^1=2,第三层2^2=4,第k层2^k。。。。

等比数列的求和公式为

因此第k层的最后一个节点下标为:2^k-1 第一个节点为2^(k-1)

因此回归正文:

  假设父节点为第K层第M个节点,则其下标为2^(k-1)+m;

其子节点就是第K+1层第2^(k)+(M-1)*2+1以及第2^(k)+(M-1)*2+2个

子左节点-父节点=2^(k)+(M-1)*2+1-2^(k-1)-M=2^(k-1)+M-1.而2^(k-1)+m为父节点下标,也就是父节点下标+1

同理 子右节点-父节点=父节点下标+2

证明完成

   二叉树的子节点的下标是父节点下标的2倍+1 以及父节点下标的2倍+2

 

 

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值