【数组二叉树】UVA - 679 Dropping Balls
程序员文章站
2024-03-18 21:58:34
...
Problem Description
每行输入深度d和小球的数量num,一个小球一个小球的下落,经过小球数为偶数开关关闭,朝左边走,奇数开关打开,朝右边走,问你最后一个小球下落在下标多少
#include<bits/stdc++.h>
using namespace std;
int main()
{
int n, d, num;
while(~scanf("%d", &n))
{
if(n == -1) break;
while(n--)
{
scanf("%d %d", &d, &num);
int k = 1;
while(k <= (1 << d) - 1)
{
if(num % 2 == 1)//如果是奇数往左走
{
k = k * 2;
num = num / 2 + 1;//走到的点,经过球的数量变为
}
else//偶数往右走
{
k = k * 2 + 1;
num = num / 2;//走到的点,经过球的数量变为
}
}
printf("%d\n", k / 2);
}
}
return 0;
}
推荐阅读
-
UVa 679 Dropping Balls【完全二叉树】
-
UVA679 小球下落 Dropping Balls
-
Uva679【Dropping Balls】找规律java题解
-
【数组二叉树】UVA - 679 Dropping Balls
-
Uva679 (完全二叉树
-
【例题 6-6 UVA - 679】Dropping Balls
-
例题6-6 小球下落(Dropping Balls, UVa 679)
-
【UVA679】Dropping Balls 解题报告
-
UVa 679 例题6-6 小球下落(Dropping Balls)
-
二叉树--uva 679 Dropping Balls 二叉树数组模拟