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 交互 二进制 随机 期望的更多相关文章

  1. Codeforces Round #649 (Div. 2)

    Codeforces Round #649 (Div. 2) -- WKL \(\mathcal{A}\)题: \(\mathrm{XXXXX}\) Greedy implementation *12 ...

  2. Codeforces Round #649 (Div. 2) C. Ehab and Prefix MEXs

    题目链接:https://codeforces.com/contest/1364/problem/C 题意 给出大小为 $n$ 的非递减数组 $a$,构造同样大小的数组 $b$,使得对于每个 $i$, ...

  3. 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 ...

  4. Codeforces Round #649 (Div. 2) A. XXXXX

    题目链接:https://codeforces.com/contest/1364/problem/A 题意 找出大小为 $n$ 的数组 $a$ 的最长连续子数组,其元素和不被 $x$ 整除. 题解 如 ...

  5. 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 ...

  6. Codeforces Round #649 (Div. 2) C. Ehab and Prefix MEXs (构造,贪心)

    题意:有长度为\(n\)的数组\(a\),要求构造一个相同长度的数组\(b\),使得\({b_{1},b_{2},....b_{i}}\)集合中没有出现过的最小的数是\(a_{i}\). 题解:完全可 ...

  7. Codeforces Round #649 (Div. 2) B. Most socially-distanced subsequence (数学,差分)

    题意:有一长度为\(n\)的数组,求一子序列,要求子序列中两两差的绝对值最大,并且子序列尽可能短. 题解:将数组看成坐标轴上的点,其实就是求每个单调区间的端点,用差分数组来判断单调性. 代码: #in ...

  8. Codeforces Round #649 (Div. 2) A. XXXXX (贪心)

    题意:有一个长度为\(n\)的数组,找一段最长子数组,使得其元素和为\(x\),如果存在,输出子数组的长度,否则输出\(-1\). 题解:这题我们要从元素和\(sum\)来考虑,首先,如果原数组的所有 ...

  9. Codeforces Round #256 (Div. 2) D. Multiplication Table(二进制搜索)

    转载请注明出处:viewmode=contents" target="_blank">http://blog.csdn.net/u012860063?viewmod ...

随机推荐

  1. 资深前端工程师带你认识网页后缀html、htm、shtml、shtm有什么区别?

    每一个网页或者说是web页都有其固定的后缀名,不同的后缀名对应着不同的文件格式和不同的规则.协议.用法,最常见的web页的后缀名是.html和.htm,但这只是web页最基本的两种文件格式,今天我们来 ...

  2. 初识C#扩展方法

    1)扩展方法是什么? 扩展方法可以在不修改原有类的代码前提下,给类“增加”一个方法.扩展方法虽然属于静态方法,但调用的语法却和对象调用类似.直接用一个例子来演示扩展方法. 1.准备实体类 public ...

  3. locust接口压测

    前言: locust是完全基于python,是一个简单易用的分布式负载测试工具 Locust特性 使用Python编写模拟用户行为的代码,无需繁琐的配置 分布式可扩展,能够支持上百万用户 自带Web界 ...

  4. 通过注入DLL修改API代码实现钩取(一)

    通过注入DLL修改API代码实现钩取(一) Ox00 大致思路 通过CreateRemoteThread函数开辟新线程,并将DLL注入进去 通过GetProcessAddress函数找到需钩取的API ...

  5. 代码注入——c++代码注入

    代码注入之——c++代码注入 0x00  代码注入和DLL注入的区别 DLL注入后DLL会通过线程常驻在某个process中,而代码注入完成之后立即消失. 代码注入体积小,不占内存 0x01  通过c ...

  6. 原生JS实现树状结构列表

    树状结构列表,这个技术点之前有写过了,是基于vue讲解,但似乎都没有解决痛点,最基础的原生JS该怎么实现呢? 这篇文章会全面详细的介绍树状结构列表的实现,从数据处理成树状结构,到动态生成dom节点渲染 ...

  7. (三)pandas 层次化索引

    pandas层次化索引 1. 创建多层行索引 1) 隐式构造 最常见的方法是给DataFrame构造函数的index参数传递两个或更多的数组 Series也可以创建多层索引 import numpy ...

  8. Scala 基础(五):Scala变量 (二) 数据类型

    1 scala数据类型介绍 Scala 与 Java有着相同的数据类型,在Scala中数据类型都是对象,也就是说scala没有java中的原生类型 Scala数据类型分为两大类 AnyVal(值类型) ...

  9. Spring-Boot 多数据源配置+动态数据源切换+多数据源事物配置实现主从数据库存储分离

    一.基础介绍 多数据源字面意思,比如说二个数据库,甚至不同类型的数据库.在用SpringBoot开发项目时,随着业务量的扩大,我们通常会进行数据库拆分或是引入其他数据库,从而我们需要配置多个数据源. ...

  10. vue : history模式与项目部署的爬坑

    需求:url不能有#符号,且不放在服务器虚拟主机的根目录. 假设放在虚拟主机的 medicine 文件夹下. 需要改两个文件,一个是 ./config/index.js (vue设置文件) ,另一个是 ...