#2315. [GESP C++六级202412] 树上游走

[GESP C++六级202412] 树上游走

Description

小杨有一棵包含无穷节点的二叉树(即每个节点都有左儿子节点和右儿子节点;除根节点外,每个节点都有父节 点),其中根节点的编号为 11,对于节点 ii,其左儿子的编号为 2×i2 \times i,右儿子的编号为 2×i+12 \times i + 1

小杨会从节点 ss 开始在二叉树上移动,每次移动为以下三种移动方式的任意一种:

- 第1种移动方式: 如果当前节点存在父亲节点,向上移动到当前节点的父亲节点,否则不移动;

- 第2种移动方式: 移动到当前节点的左儿子;

- 第3种移动方式: 移动到当前节点的右儿子。

小杨想知道移动 nn 次后自己所处的节点编号。数据保证最后的所处的节点编号不超过 101210^{12}

Input Format

第一行包含一个正整数 n,sn, s,代表移动次数和初始节点编号。

第二行包含一个长度为 nn 且仅包含大写字母 U,L,RU,L,R 的字符串,代表每次移动的方式,其中 UU 代表第 11 种移动方式,LL 代表第22种移动方式,RR 代表第33种移动方式。

Output Format

输出一个正整数,代表最后所处的节点编号。

3 2
URR

7

Hint

样例解释

小杨的移动路线为 21372-1-3-7

数据范围

子任务编号 数据点占比 nn ss
1 20% 20\% 10\leq 10 2\leq 2
2 20%20\% 50\leq 50 10\leq 10
3 60%60\% 106\leq 10^6 1012\leq 10^{12}

对于全部数据,保证有 1n1061s10121 \leq n \leq 10^6, 1 \leq s \leq 10^{12}

Source

2024年12月GESP C++六级