小猴子下落
题目描述:
有一颗二叉树,最大深度为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
按照满二叉树的性质写的,没什么难度吧,但是,提交了很多次,就是不AC,看来得好好反省了
#include<iostream>
#include<iomanip>
#include<algorithm>
#include<cstring>
#include<sstream>
#include<cmath>
#define NUM 20010
int onOff[NUM];
using namespace std;
int main()
{
int D,I,len,nowNode,ans;
while(cin>>D>>I){
if(D==0)
break;
memset(onOff,0,sizeof(onOff));
len=1;
for(int i=1; i<=D; i++){
len*=2;
}
nowNode=2;
ans=1;
for(int i=1; i<=I; i++){
nowNode=1;
while(nowNode<len){//退出的时候找到父节点
ans=nowNode;
if(onOff[nowNode]==0){//off
onOff[nowNode]=1;
nowNode = nowNode*2;
}else{
onOff[nowNode]=0;
nowNode = nowNode*2+1;
}
}
}
cout << ans << endl;
}
return 0;
}