zoukankan      html  css  js  c++  java
  • 小猴子下落(二叉树,思维)

    小猴子下落

    时间限制:3000 ms  |  内存限制:65535 KB
    难度:3
     
    描述

    有一颗二叉树,最大深度为D,且所有叶子的深度都相同。所有结点从左到右从上到下的编号为1,2,3,·····,2的D次方减1。在结点1处放一个小猴子,它会往下跑。每个内结点上都有一个开关,初始全部关闭,当每次有小猴子跑到一个开关上时,它的状态都会改变,当到达一个内结点时,如果开关关闭,小猴子往左走,否则往右走,直到走到叶子结点。

    一些小猴子从结点1处开始往下跑,最后一个小猴儿会跑到哪里呢?

     
    输入
    输入二叉树叶子的深度D,和小猴子数目I,假设I不超过整棵树的叶子个数,D<=20.最终以 0 0 结尾
    输出
    输出第I个小猴子所在的叶子编号。
    样例输入
    4 2
    3 4
    0 0
    样例输出
    12
    7
    题解:水题,每次猴子下一层,如果是奇数就往左,还剩i/2+1个猴子;偶数就往右树,还剩i/2个;
    代码:
    #include<cstdio>
    #include<iostream>
    #include<cmath>
    #include<algorithm>
    #include<cstring>
    #include<queue>
    #include<stack>
    using namespace std;
    const int INF=0x3f3f3f3f;
    #define mem(x,y) memset(x,y,sizeof(x))
    #define SI(x) scanf("%d",&x)
    #define PI(x) printf("%d",x)
    #define ll root<<1
    #define rr root<<1|1
    typedef long long LL;
    int dfs(int root,int d,int i){
        if(d==1){
            return root;
        }
        if(i%2||i==0)return dfs(ll,d-1,1+i/2);
        else return dfs(rr,d-1,i/2);
    }
    int main(){
        int D,I;
        while(~scanf("%d%d",&D,&I),D|I){
            printf("%d
    ",dfs(1,D,I));
        }
        return 0;
    }
  • 相关阅读:
    居中
    背景和内容
    Filter 解决web网页跳转乱码
    java内部类
    javascript 基础教程[温故而知新一]
    每隔一秒自动执行函数(JavaScript)
    详解 Android Activity 生命周期
    css 重新学习系列(3)
    css 重新学习系列(2)
    写一个迷你版Smarty模板引擎,对认识模板引擎原理非常好(附代码)
  • 原文地址:https://www.cnblogs.com/handsomecui/p/5240791.html
Copyright © 2011-2022 走看看