URAL 1117. Hierarchy(DP)

题目链接

这破题,根本看不懂题意啊。。。题意:一棵中序遍历是1 2 3 4 5...的满二叉树,从a a+1 a+2 a+3 b,总共多少步。x到y的距离为中间有多少个点。a > b没注意2Y。

 1 #include <cstring>
 2 #include <cstdio>
 3 #include <string>
 4 #include <iostream>
 5 #include <algorithm>
 6 #include <cmath>
 7 #include <map>
 8 using namespace std;
 9 int bin[60];
10 int judge(int x)
11 {
12     int i,temp;
13     if(x <= 0)
14     return 0;
15     for(i = 31;i >= 0;i --)
16     {
17         if(x&(1<<i))
18         {
19             temp = x-(1<<i);
20             if(temp)
21             return bin[i] + judge(temp) + i - 1;
22             else
23             return bin[i];
24         }
25     }
26     return 0;
27 }
28 int main()
29 {
30     int i,a,b;
31     bin[0] = bin[1] = 0;
32     for(i = 2;i <= 31;i ++)
33     {
34         bin[i] = 2*bin[i-1] + i-1;
35     }
36     scanf("%d%d",&a,&b);
37     if(a > b)
38     swap(a,b);
39     printf("%d\n",judge(b)-judge(a));
40     return 0;
41 }

 

转载于:https://www.cnblogs.com/naix-x/p/3312566.html

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值