博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Codeforces.1129E.Legendary Tree(交互 二分)
阅读量:4963 次
发布时间:2019-06-12

本文共 2007 字,大约阅读时间需要 6 分钟。


\(Description\)

有一棵\(n\)个点的树。你需要在\(11111\)次询问内确定出这棵树的形态。每次询问你给定两个非空且不相交的点集\(S,T\)和一个点\(u\),交互库会告诉你满足\(x\in S,y\in T\),且\(x\to y\)经过了\(u\)的点对\((x,y)\)的数量。

\(n\leq500\)

\(Solution\)

不妨假设以\(1\)为根。首先如果想知道\(y\)是否在\(x\)的子树内,询问\(S=\{1\},T=\{y\},u=x\)就可以了(同样可以扩展到某点集中有多少个点在\(x\)子树内)。

那么对于每个点\(i\),询问\(S=\{1\},T=\{2,3,...,n\},u=i\),就可以知道\(i\)子树的大小\(size_i\)
有什么用呢。。把所有点按\(size_i\)从大到小排序,那么该序列中每个点的父节点一定在它的左边。
(PS:这个序列还可以增量构造出来:考虑在已有\(1...i\)的序列中加入\(i+1\),二分找到一个最靠右的点\(p\),满足\(a_1,a_2,...,a_p\)没有点在\(i+1\)的子树中,然后把\(i+1\)插入到\(a_p\)后面即可。需要\(O(n\log n)\)次询问。)
考虑从右往左扫这个序列,对每个节点找出它直属的儿子。
假设当前是点\(i\),设\(i\)后面还没有找到父亲的点集是\(P\)。首先查一次\(P\)中是否没有点在\(i\)的子树中。\(S=\{1\},T=P,u=i\)询问一次即可。
\(P\)中存在\(i\)子树内的点,可以二分找出\(P\)中最靠左的一个\(i\)的儿子\(P_j\),连边\((i,p)\)。然后再对\(P'=\{P_{j+1},P_{j+2},...\}\)继续重复上边过程即可。
询问次数\(O(n\log n)+2n\)。(数据实测最多\(<5500\))(有\(200\)组数据=-=)


#include 
#include
#include
#include
#define pc putchar#define Flush() fflush(stdout)#define gc() getchar()typedef long long LL;const int N=505;int id[N],sz[N],fa[N];inline int read(){ int now=0,f=1;register char c=gc(); for(;!isdigit(c);c=='-'&&(f=-1),c=gc()); for(;isdigit(c);now=now*10+c-48,c=gc()); return now*f;}inline bool cmp(int a,int b){ return sz[a]>sz[b];}int Query_Size(int x,int n){ printf("1\n1\n%d\n",n-1); for(int i=2; i<=n; ++i) printf("%d ",i); return printf("\n%d\n",x),Flush(),read();}int Query_Exist(int x,const std::vector
&vec,int r)//vec中存在x子树中的点 { printf("1\n1\n%d\n",r); for(int i=0; i
vec; for(int i=n; i; --i) { int x=id[i]; std::vector
P=vec,tmp; while(!P.empty()&&Query_Exist(x,P,P.size())) { int l=1,r=P.size(),mid; while(l
>1)) r=mid; else l=mid+1; fa[P[--l]]=x; auto it=P.begin(); while(l--) tmp.push_back(*it++); P.erase(P.begin(),++it); } for(auto v:P) tmp.push_back(v); vec=tmp, vec.push_back(x); } puts("ANSWER"); for(int i=2; i<=n; ++i) printf("%d %d\n",fa[i],i); return 0;}

转载于:https://www.cnblogs.com/SovietPower/p/10758851.html

你可能感兴趣的文章
SpringMVC GET请求中文数据传递到Server端乱码
查看>>
eclipse 关闭web项目无用校验
查看>>
js 根据身份证获取出生日期及性别
查看>>
PHPstorm+XDebug+Chrome/Firefox超详细教程(图文)
查看>>
织梦常用标签汇总-------未完待续
查看>>
VMWare ESX/ESXi 虚拟机硬盘的厚置备(Thick Provision)与精简置备(Thin Provision)的转换
查看>>
(译文)Python中的staticmethod与classmethod
查看>>
表单验证
查看>>
总结-SQL注入
查看>>
pytorch-tensor处理速查表(cat stack squeeze unsqueeze permute等)
查看>>
今天的谈话
查看>>
最大熵模型---关毅老师的课件
查看>>
javaScript 简单的时间格式转换【转】
查看>>
解析AFNetWorking 网络框架(二)
查看>>
ThinkPHP5的模板替换__STATIC__
查看>>
Time Complexity of Loop with Powers
查看>>
python高级特性
查看>>
Linux编程之PING的实现
查看>>
[iOS开发]ShareSDK
查看>>
上一家公司倒闭,为什么我又来了创业公司?
查看>>