UVA 679 Dropping Balls

探讨如何确定第m个小球在满二叉树中最终落下的节点位置,通过递归判断小球沿左右子树下落的过程,提供了一个有效的算法实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

题目大意:有一个满二叉树,开始的时候节点的值全都是false,接着会有小球陆续的落下来。如果小球落到某个节点,如果当前节点的值为false,那么节点的值由false变为true,小球便沿着左子树落下去;否则,节点的值由true变为false,小球沿着右子树下落。直到落到叶子结点结束。
题目给出二叉树的层数和第几个小球,问小球会落在那个节点。(节点依次编号为1.2.3……)
我们可以想象,小球在根节点的时候,一定是第1,3,5,7……个小球落在左子树,2,4,6,8……落在右子树。再向下看,假设我们现在在根节点的左子树上,那么就会发现第1,5,9……落在左子树,其他的落在右子树。那么就是所有落在当前节点的小球中,第2n - 1(n=1.2.3.4……)个落在左子树,第2n(n=1.2.3.4……)个落在右子树。
如果题目给的是第m个小球,如果m是偶数,那么,小球的一定是向右子树落的,就将当前答案ans*2+1(到达右子树),将m / 2;否则,小球是向左子树落的,当前答案ans*2,m = (m + 1) / 2;
……

#include<iostream>
using namespace std;

int main()
{
    int ans = 1,n,m;
    int t;
    cin>>t;
    while(t--,cin>>n,n>0){
        ans = 1;
        cin>>m;
        for(int i = 1;i < n;i++){
            if (m % 2) {
                ans = ans * 2;
                m = (m + 1) / 2;
            } else {
                ans = ans * 2 + 1;
                m = m / 2;
            }
        } 
        cout<<ans<<endl;
    }
    return 0;
} 
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值