CF 792D
来源:互联网 发布:淘宝怎么设置客服号 编辑:程序博客网 时间:2024/06/06 09:37
题目链接:http://codeforces.com/contest/792/problem/D
题意:根据给的这种满二叉树,U移动到父节点,R移动到右节点。L移动到左节点,当然不能继续移动不要用,问最后的数字是多少?
解法:把数字转成二进制,看看num&(-num)得到当前节点同层的最左边的节点是什么,num&-num就是树状数组里面的lowbit。
pos=num&(-num), num&(pos*2)得出当前在左边还是右边,然后模拟。
//CF 792D#include <bits/stdc++.h>using namespace std;long long n, m, num, root;string s;int main(){ scanf("%lld%lld", &n, &m); root = (n+1)/2; for(int i = 1; i <= m; i++){ cin >> num >> s; for(int j = 0; j < s.size(); j++){ //cout << s[j] << endl; long long pos = (num&-num); if(s[j] == 'U' && num != root){ if((num&(pos*2))){ num-=pos; } else{ num+=pos; } } else if(s[j] == 'L'){ pos/=2; num-=pos; } else if(s[j] == 'R'){ pos/=2; num+=pos; } } printf("%lld\n", num); } return 0;}
0 0
- CF 792D
- CF D. Buses
- D. Ball CF
- CF 148D
- CF 173D-- Palindromes
- CF 228D Zigzag
- CF 79D. Password
- CF 214D
- CF 109D
- CF 109D 模拟
- CF 85D
- CF 12D. Ball
- CF 174(div2) D
- CF 161 div2 D
- CF 189 div2 D
- CF 159 div2 d
- CF 313D
- CF 15D Map
- 包含min函数的栈
- java学习之队列的实现
- 【caffe】win7+vs2013+安装NuGet
- 行为型模式-访问者(visitor)
- JavaScript通用继承方法和super
- CF 792D
- c 程序设计语言 第二版 练习题 4-12
- LOI Online Judge 33. 【2017.4.1】面包店
- solr初级教程
- Unity协程
- sequelize -- Model的详细定义
- MyBatis框架基于Annotation注解的一对多关联映射
- C++中的头文件和源文件:如何写头文件
- BufferedInputStream/BufferedOutputStream、BufferedWriter/BufferedReader介绍