uva679 Dropping Balls
来源:互联网 发布:什么虚拟机可以装mac 编辑:程序博客网 时间:2024/05/16 13:06
球从根节点往下落,初始化所有开关为0,0球向左边,1球向右边落。
输入树的层数和球的个数,问最后一个球落在那个叶子节点上?
思路:由于每层都是满的,可以用一个一维数组建树模拟,每个球的过程。
#include <fstream>#include <iostream>#include <string>#include <cstring>#include <complex>#include <math.h>#include <set>#include <vector>#include <map>#include <queue>#include <stdio.h>#include <stack>#include <algorithm>#include <list>#include <ctime>#include <ctime>#include <assert.h>#define rep(i,a,n) for (int i=a;i<n;i++)#define per(i,a,n) for (int i=n-1;i>=a;i--)#define pb push_back#define mp make_pair#define all(x) (x).begin(),(x).end()#define fi first#define se second#define eps 1e-8#define M_PI 3.141592653589793typedef long long ll;const ll mod=1000000007;const int inf=0x7fffffff;ll powmod(ll a,ll b) {ll res=1;a%=mod;for(;b;b>>=1){if(b&1)res=res*a%mod;a=a*a%mod;}return res;}using namespace std;bool tree[1<<22];int main(){ int T; while(scanf("%d",&T)&&T>0){ int n,t,cur; while(T--){ scanf("%d%d",&n,&t); memset(tree,false,sizeof(tree)); int sum=(1<<n)-1; //cout<<sum<<endl; while(t--){ cur=1; while(cur*2<=sum){ int p=cur; //cout<<tree[cur]<<" oo "<<endl; if(!tree[cur]) cur=cur*2; else cur=cur*2+1; tree[p]=!tree[p]; } } printf("%d\n",cur); } }}
TLE
分析,对于每个小球只需知道他是第几个落入这个点的(奇还是偶),就知道他要往左还是右,所以只用考虑最后一个点,对于每层的情况。
#include<iostream>using namespace std;int main(){ int T; while(cin>>T&&T!=-1){ while(T--){ int n,m;cin>>n>>m; int t=1; n--; while(n--){ if(m%2){ t=t*2; m=m/2+1; } else{ t=t*2+1; m/=2; } } cout<<t<<endl; } }}
1 0
- uva679 dropping balls
- uva679 Dropping Balls
- Dropping Balls, UVa679
- BNU17818 UVA679 Dropping Balls
- UVa679: dropping balls
- uva679 Dropping Balls
- Dropping Balls, UVa679
- UVA679 Dropping Balls【二叉树结点编号】
- uva679--Dropping Balls--满二叉树
- UVa679(Dropping Balls)(二叉树的编号)
- UVa679-Dropping Balls-小球下落-二叉树的编号
- Dropping Balls
- Dropping Balls
- Dropping Balls
- UVA 679 - Dropping Balls
- uva 679 - Dropping Balls
- UVa 679 Dropping Balls
- UVA - 679 Dropping Balls
- Git协作流程
- 创建型模式5之2-AbstractFactory抽象工厂模式例子理解
- Controller生命周期
- WebViewJavascriptBridge使用分析(二)
- iphone导入通讯录
- uva679 Dropping Balls
- 打开有EditText的界面不要自动弹出输入法
- Ubuntu出现error:unknown filesystem grub rescue解决办法
- sqlzoo练习答案--Using Null
- Android6.0 Run-time permission
- iOS开发之:dispatch_async 与 dispatch_get_global_queue 的使用方法
- Spring中使用Interceptor拦截器拦截请求
- 中医教你怎么睡好觉,睡个养生觉!
- 复制列表