P11375 [GESP202412 六级] 树上游走

六级标题题目来源

https://www.luogu.com.cn/problem/P11375

题目背景

对应的选择、判断题:试题 - GESP 202412 C++ 六级 - 洛谷有题

题目描述

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

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

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

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

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

小杨想知道移动 n 次后自己所处的节点编号。数据保证最后所处的节点编号不超过 1012。

输入格式

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

第二行包含一个长度为 n 且仅包含大写字母 U、L 和 R 的字符串,代表每次移动的方式,其中 U 代表第 1 种移动方式,L 代表第 2 种移动方式,R 代表第 3 种移动方式。

输出格式

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

输入输出样例

输入 #1

3 2

URR

输出 #1

7

说明/提示

小杨的移动路线为 2→1→3→7。

子任务编号 数据点占比 n s

1 20% ≤10 ≤2

2 20% ≤50 ≤10

3 60% ≤ ≤

对于全部数据,保证有 1≤n≤,1≤s≤。

强调!!!!!

洛谷上的标签是高精度,但是long long就可以解决。

太水了

代码

cpp 复制代码
#include <bits/stdc++.h>
using namespace std;
stack<long long> s;
stack<long long> w;
int main() {
	int c;
	long long x;
	cin>>c>>x;
	long long d=x;
	while(d!=1) {
		d/=2;
		w.push(d);
	}
	while(!w.empty()) {
		s.push(w.top());
		w.pop();
	}
	while(c--) {
		char p;
		cin>>p;
		if(p=='U'&&x!=1) {
			if(!s.empty()) {
				x=s.top();
				s.pop();
			}
		}
		if(p=='L') {
			s.push(x);
			x*=2;
		}
		if(p=='R') {
			s.push(x);
			x=x*2+1;
		}
	}
	cout<<x;
	return 0;
}

无耻求关

相关推荐
_清歌10 小时前
DSpark 深度解读:DeepSeek-V4 如何用「半自回归」把推理速度提升 85%
算法
统计实现局10 小时前
SVD 的三步走:双对角化、Givens 收敛、排序
算法
躬行见万象10 小时前
《VLA 系列》UniLab 强化训练 | G1 机器人 |复现
算法
统计实现局10 小时前
对称不定分解(Bunch-Kaufman):为什么 Cholesky 不够用
算法
统计实现局10 小时前
dqrsl 拆解:拿着 QR 结果能算出哪 5 种东西
算法
统计实现局10 小时前
为什么 Cholesky 求逆比 Gauss-Jordan 快一倍——行列式溢出防护详
算法
To_OC1 天前
LC 994 腐烂的橘子:人人都说是 BFS 入门题,我却写了三遍才过
javascript·算法·leetcode
金銀銅鐵1 天前
[Python] 扩展欧几里得算法
python·数学·算法
To_OC1 天前
LC 200 岛屿数量:经典 DFS 入门题,我第一次写居然连方向都搞错了
javascript·算法·leetcode