Codeforces Round #649 (Div. 2) E. X-OR 交互 二进制 随机 期望
LINK:X-OR
本来是应该昨天晚上发的 可是昨天晚上 做这道题 写了一个分治做法 一直wa
然后查错 查不出来 心态崩了 想写对拍 发现交互库自己写不出来。
一系列sb操作 == 我都醉了。
今天重构了代码 换了另外一种做法就很快就过了。
考虑怎么做:求出所有位置上的数字是谁 光凭异或是很难异或出来的。
或许可以快速察觉到一个做法 对于每一位来做 然后 找到第i为为0的是谁 这样就得到了一个nlogn的做法。
会爆掉询问次数。
发现如果逐一找到每个位置上是谁的话 更快需要找到0所在。
考虑如何找0 在已经有一个函数可以帮忙确定某一位是谁的情况下。
容易得到 随便找个数字开始或 然后 遇到刚好等于自己的 说明 对方是自己的子集 难么进行一次替换。
最终就会替换到0.
这样的过程是O(n)+log^2的 最后再来一次O(n)的扫描 就可以通过了。
可以利用map 来优化询问次数.一开始每一位的确定位置可以直接rand 期望下是很快的。
考虑分治做法:
考虑一种确定一个数字是谁的方法:O(n)暴力扫 然后得到的最小值就是自己的值当然0除外.
那么我们可以拿到一个值 然后 把自己的子集都给搞出来 不断重复这个过程 直至只剩下两个数字。
每次选取当前二进制下的一半 这样随机的效率较高。
期望下询问次数也不超过2n+c 所以可以通过 不过不知道为什么我写挂了...
这里是第一种做法:
const int MAXN=2050;
int n,m=11;
int p[MAXN];
int sum[MAXN],b[MAXN];
inline int ask(int i,int j)
{
cout<<"?"<<' '<<i<<' '<<j<<endl;
int x;cin>>x;return x;
}
inline int re(int x){return rand()%x+1;}
inline int gs(int x)
{
int ans=0;
vep(0,m,i)
{
int ww=0;
if(b[i]!=x)ww=ask(b[i],x);
if(ww&(1<<i))ans|=(1<<i);
}
return ans;
}
int main()
{
//freopen("1.in","r",stdin);
ios::sync_with_stdio(false);
srand(time(0));
cin>>n;
int cnt=0;
while(cnt<m)
{
int x=re(n);int y=re(n);
if(x==y)continue;
int ww=ask(x,y);
vep(0,m,i)if(!(ww&(1<<i))&&!b[i])
{
b[i]=x;++cnt;
}
}
cout<<"ww"<<endl;
int ww=gs(1),pos=1;
rep(2,n,i)
{
int x=ask(pos,i);
if(x<=ww)
{
pos=i;
ww=gs(i);
}
}
rep(1,n,i)if(pos!=i)p[i]=ask(pos,i);
cout<<"!";
rep(1,n,i)cout<<' '<<p[i];
return 0;
}
Codeforces Round #649 (Div. 2) E. X-OR 交互 二进制 随机 期望的更多相关文章
- Codeforces Round #649 (Div. 2)
Codeforces Round #649 (Div. 2) -- WKL \(\mathcal{A}\)题: \(\mathrm{XXXXX}\) Greedy implementation *12 ...
- Codeforces Round #649 (Div. 2) C. Ehab and Prefix MEXs
题目链接:https://codeforces.com/contest/1364/problem/C 题意 给出大小为 $n$ 的非递减数组 $a$,构造同样大小的数组 $b$,使得对于每个 $i$, ...
- Codeforces Round #649 (Div. 2) B. Most socially-distanced subsequence
题目链接:https://codeforces.com/contest/1364/problem/B 题意 给出大小为 $n$ 的一个排列 $p$,找出子序列 $s$,使得 $|s_1-s_2|+|s ...
- Codeforces Round #649 (Div. 2) A. XXXXX
题目链接:https://codeforces.com/contest/1364/problem/A 题意 找出大小为 $n$ 的数组 $a$ 的最长连续子数组,其元素和不被 $x$ 整除. 题解 如 ...
- Codeforces Round #649 (Div. 2) C、Ehab and Prefix MEXs D、Ehab's Last Corollary 找环和点染色
题目链接:C.Ehab and Prefix MEXs 题意; 有长度为n的数组a(下标从1开始),要求构造一个相同长度的数组b,使得b1,b2,....bi集合中没有出现过的最小的数是ai. mex ...
- Codeforces Round #649 (Div. 2) C. Ehab and Prefix MEXs (构造,贪心)
题意:有长度为\(n\)的数组\(a\),要求构造一个相同长度的数组\(b\),使得\({b_{1},b_{2},....b_{i}}\)集合中没有出现过的最小的数是\(a_{i}\). 题解:完全可 ...
- Codeforces Round #649 (Div. 2) B. Most socially-distanced subsequence (数学,差分)
题意:有一长度为\(n\)的数组,求一子序列,要求子序列中两两差的绝对值最大,并且子序列尽可能短. 题解:将数组看成坐标轴上的点,其实就是求每个单调区间的端点,用差分数组来判断单调性. 代码: #in ...
- Codeforces Round #649 (Div. 2) A. XXXXX (贪心)
题意:有一个长度为\(n\)的数组,找一段最长子数组,使得其元素和为\(x\),如果存在,输出子数组的长度,否则输出\(-1\). 题解:这题我们要从元素和\(sum\)来考虑,首先,如果原数组的所有 ...
- Codeforces Round #256 (Div. 2) D. Multiplication Table(二进制搜索)
转载请注明出处:viewmode=contents" target="_blank">http://blog.csdn.net/u012860063?viewmod ...
随机推荐
- CF819B Mister B and PR Shifts 思维题
分析 这道题\(n\leq10^{6}\),显然\(n^{2}\)的暴力是无法解决问题的 那么我们可以考虑数列的某一种性质 因为最终的答案是\(\sum{n \atop i=1} |p_i - i|\ ...
- 有点愧疚,今天把unity官方骗了...
今天下午2点,突然给我发了一封邮件说我违规: Unity Technologies Hello, Your Account: *@*.net has been suspended and you ca ...
- __stdcall、__cdcel和__fastcall三者的区别
转自:https://www.cnblogs.com/huhewei/p/6080143.html 一.概述 __stdcall.__cdecl和__fastcall是三种函数调用协议,函数调用协议会 ...
- C++左值引用与右值引用
本文翻译自:https://docs.microsoft.com/en-us/cpp/cpp/references-cpp?view=vs-2019 引用,类似于指针,用于存储一个位于内存某处的对象的 ...
- web 安全之页面解析的流程学习
0x00 任务内容: 理解域名解析的整个过程 理解 web 页面请求的整个流程,绘制流程图(nginx 处理的 11 个过程) 学习 http 协议中的字段及含义 学习 http 请求方法以及返回状态 ...
- JVM 专题二十二:垃圾回收(六)垃圾回收器 (三)
4. GC日志分析 4.1 日志分析 通过阅读GC日志,我们可以了解Java虚拟机内存分配与回收策略. 内存分配与垃圾回收的参数列表-XX:+PrintGC:输出GC日志.类似-verbose: gc ...
- 转载一篇关于kafka零拷贝(zero-copy)通俗易懂的好文
原文地址 https://www.cnblogs.com/yizhou35/p/12026263.html 零拷贝就是一种避免CPU 将数据从一块存储拷贝到另外一块存储的技术. DMA技术是Direc ...
- kafka零拷贝
Kafka之所以那么快的另外一个原因就是零拷贝(zero-copy)技术.本文我们就来了解Kafka中使用的零拷贝技术为什么那么快. 传统的文件拷贝 传统的文件拷贝通常需要从用户态去转到核心态,经过r ...
- Ethical Hacking - GAINING ACCESS(19)
Client-Side Attacks - Social Engineering Tool: The FAT RAT Just like Veil, it generates Undetectable ...
- C++ 线性筛素数
今天要写一篇亲民的博客了,尽力帮助一下那些不会线性筛素数或者突然忘记线性筛素数的大佬. 众所周知,一个素数的倍数肯定不是素数(废话).所以我们可以找到一个方法,普通的筛法(其实不算筛,普通的是判断一个 ...