【luogu CF1061F】Lost Root(思维)(树)

Lost Root

题目链接:luogu CF1061F

题目大意

给你一棵满 k 叉树,然后你每次可以询问一个点是否在两个点的路径中。
然后要你通过不超过 60n 次询问得出根节点的位置。

思路

这题其实挺神奇的。
首先我们可以算出树的深度 deg

我们考虑随机找,那找什么呢?
我们考虑找到两个叶子节点,然后要它们是在根的不同的儿子的子树中。

这样有什么用呢,那根节点就在它们的路径上,而且你可以知道这条路径上有多少个点:2deg1

然后这个是有概率的:
选中同一个儿子的概率是 1k,反之则是 k1k
(然后这个东西最小的应该是 k=2 的时候是 12

然后叶子节点的数量占到了大概是 12
然后选到两个都是概率 14

所以整个选到的概率是 18,然后你每次试要 n 次操作,所以你有接近 60 次尝试,这个找到的概率很大。

然后你找到之后就是要找到根节点。
那你找根节点也可以用同样类似的方法,你之前记录下在那两个点之间的点,然后依次找。
然后如果它在 deg1 个点和其中一个叶子节点的路径之间的话,那它就是根节点。(显然)

然后就可以了。

代码

#include<cstdio> #include<cstring> #include<cstdlib> #define Pass fflush(stdout) using namespace std; int n, k, deg, sum; int in[1501], x, y; int get_deg(int n, int k) { int re = 1, now = 1, tot = 1; while (tot < n) { now *= k; re++; tot += now; } return re; } bool check(int x, int y) { int num = 0; for (int i = 1; i <= sum; i++) if (in[i] != y) { printf("? %d %d %d\n", x, in[i], y); Pass; char tmp; tmp = getchar(); while (tmp != 'N' && tmp != 'Y') tmp = getchar(); if (tmp == 'N') getchar(); else getchar(), getchar(); if (tmp == 'Y') { num++; } } if (num == deg - 1) return 1; return 0; } int main() { srand(114514); scanf("%d %d", &n, &k); deg = get_deg(n, k); deg--; while (sum != 2 * deg - 1) {//直接随机找 sum = 0; memset(in, 0, sizeof(in)); x = rand() % n + 1; y = rand() % n + 1; while (x == y) y = rand() % n + 1; for (int i = 1; i <= n; i++) if (i != x && i != y) { printf("? %d %d %d\n", x, i, y); Pass; char tmp; tmp = getchar(); while (tmp != 'N' && tmp != 'Y') tmp = getchar(); if (tmp == 'N') getchar(); else getchar(), getchar(); if (tmp == 'Y') { in[++sum] = i; } } } for (int i = 1; i <= sum; i++) {//然后直接找到根 if (check(x, in[i])) { printf("! %d", in[i]); return 0; } } return 0; }

__EOF__

本文作者あおいSakura
本文链接https://www.cnblogs.com/Sakura-TJH/p/luogu_CF1061F.html
关于博主:评论和私信会在第一时间回复。或者直接私信我。
版权声明:本博客所有文章除特别声明外,均采用 BY-NC-SA 许可协议。转载请注明出处!
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角推荐一下。您的鼓励是博主的最大动力!
posted @   あおいSakura  阅读(29)  评论(0编辑  收藏  举报
编辑推荐:
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
阅读排行:
· 分享一个免费、快速、无限量使用的满血 DeepSeek R1 模型,支持深度思考和联网搜索!
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· ollama系列01:轻松3步本地部署deepseek,普通电脑可用
· 25岁的心里话
· 按钮权限的设计及实现
点击右上角即可分享
微信分享提示