完全二叉树——求结点个数

题目描述

    如上所示,由正整数1,2,3……组成了一颗特殊二叉树。我们已知这个二叉树的最后一个结点是n。现在的问题是,结点m所在的子树中一共包括多少个结点。     比如,n = 12,m = 3那么上图中的结点13,14,15以及后面的结点都是不存在的,结点m所在子树中包括的结点有3,6,7,12,因此结点m的所在子树中共有4个结点。

输入描述:

    输入数据包括多行,每行给出一组测试数据,包括两个整数m,n (1 <= m <= n <= 1000000000)。

输出描述:

    对于每一组测试数据,输出一行,该行包含一个整数,给出结点m所在子树中包括的结点的数目。
示例1

输入

复制
3 12

输出

复制
4
#include<iostream>
using namespace std;
int count=0;
void solve(int n,int maxx)
{

    if(n<=maxx)count++;
    else return ;
    solve(n*2,maxx);
    solve(n*2+1,maxx);
}
int main()
{
    int n,maxx;
    while(cin>>n>>maxx)
    {
        solve(n,maxx);
        cout<<count<<endl;
    }
}


猜你喜欢

转载自blog.csdn.net/qq_38030194/article/details/80804117