2158: 树上游走(2024年12月GESP C++六级)
Memory Limit:128 MB
Time Limit:1.000 S
Judge Style:Text Compare
Creator:
Submit:45
Solved:19
Description
小杨有一棵包含无穷节点的二叉树(即每个节点都有左儿子节点和右儿子节点;除根节点外,每个节点都有父节点),其中根节点的编号为1,对于节点 i ,其左儿子的编号为 2 * i ,右儿子的编号为 2 * i +1 。
小杨会从节点 s 开始在二叉树上移动,每次移动为以下三种移动方式的任意一种:
- 第 1 种移动方式 U :如果当前节点存在父亲节点,向上移动到当前节点的父节点,否则不移动;
- 第 2 种移动方式 L :移动到当前节点的左儿子;
- 第 3 种移动方式 R :移动到当前节点的右儿子。
小杨想知道移动 n 次后自己所处的节点编号。数据保证最后所处的节点编号不超过 1012。
Input
第一行包含两个正整数 n 和 S ,代表移动次数和初始节点编号。
第二行包含一个长度为 n 且仅包含大写字母 U、L 和 R 的字符串,代表每次移动的方式,其中 U 代表第 1 种移动方式, L 代表第 2 种移动方式,R代表第 3 种移动方式。
Output
输出一个正整数,代表最后所处的节点编号。
Sample Input Copy
3 2
URR
Sample Output Copy
7
HINT
小杨的移动路线为 2->1->3->7.
对于全部数据,保证有 1<=n<=106, 1<=s<=1012.