CF835E-The penguin‘s game【交互】
正题
题目链接:https://www.luogu.com.cn/problem/CF835E
题目大意
长度为\(n\)的序列中有两个\(y\)其他都是\(x\),给出\(n,x,y\)。你每次可以询问一个下标集合的数字异或和,要求在\(19\)次以内找到这两个\(y\)的位置。
\(1\leq n\leq 1000,1\leq x,y\leq 10^9,x\neq y\)
解题思路
考虑询问一个集合我们会得到的答案情况,如果集合大小为奇数则为\(y\)或者\(x\)依次表示\(y\)分别在一个集合内或者都在某个集合中,而偶数则是\(x\ xor\ y\)或者\(0\)。
现在变为了我们可以询问一个集合回答两个\(y\)都在一个集合内或外或者一个在内一个在外。
考虑到两个数字的下标肯定有一个二进制位不同,我们可以枚举这个位然后询问这个位是\(1\)的元素。这样我们总能找到一个集合使得一个\(y\)在内,一个\(y\)在外。
如果在这个两个集合里面暴力问的话算上前面的次数大概是\(3\log n\)的,考虑优化。
发现对于前面的询问,我们可以得到两个集合下标的异或值,所以如果我们问出一个位置再异或出另一个就好了。
因为是\(19\)次所以我们考虑找比较小的那个集合的值就好了。
code
#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N=1100;
int n,x,y,cnt,p[N],ansa,ansb;
void Ask(int l,int r){
if(l==r){ansa=p[l];return;}
int mid=(l+r)>>1,ans,flag=0;
printf("? %d",mid-l+1);
for(int i=l;i<=mid;i++)
printf(" %d",p[i]);
putchar('\n');fflush(stdout);
scanf("%d",&ans);
if((mid-l+1)&1)flag=(ans==y);
else flag=(ans==(x^y));
if(flag)Ask(l,mid);
else Ask(mid+1,r);
return;
}
void Find(int z){
cnt=0;
for(int i=1;i<=n;i++)
if((i/z)&1)p[++cnt]=i;
if(cnt>(n/2)){
cnt=0;
for(int i=1;i<=n;i++)
if(!((i/z)&1))p[++cnt]=i;
}
Ask(1,cnt);
}
int main()
{
scanf("%d%d%d",&n,&x,&y);
bool has=0;
for(int z=1;z<=n;z<<=1){
int L=0,ans,flag=0;putchar('?');
for(int i=1;i<=n;i++)if((i/z)&1)L++;
printf(" %d",L);
for(int i=1;i<=n;i++)if((i/z)&1)printf(" %d",i);
putchar('\n');fflush(stdout);
scanf("%d",&ans);
if(L&1)flag=(ans==y);
else flag=(ans==(x^y));
if(flag&&!has)Find(z),has=1;
ansb^=z*flag;
}
ansb^=ansa;
if(ansa>ansb)swap(ansa,ansb);
printf("! %d %d\n",ansa,ansb);
fflush(stdout);
return 0;
}
CF835E-The penguin‘s game【交互】的更多相关文章
- Codeforces.835E.The penguin's game(交互 按位统计 二分)
题目链接 \(Description\) 有一个长为\(n\)的序列,其中有两个元素为\(y\),其余全为\(x\).你可以进行\(19\)次询问,每次询问你给出一个下标集合,交互库会返回这些元素的异 ...
- Codeforces Round #427 (Div. 2) E. The penguin's game (交互题,二进制分组)
E. The penguin's game time limit per test: 1 second memory limit per test: 256 megabytes input: stan ...
- Sublime Text3配置在可交互环境下运行python快捷键
安装插件 在Sublime Text3下面写代码感觉很不错,但是写Python的时候遇到了一些问题. 用Sublime Text3打开python文件,或者在Sublime Text3下写好pytho ...
- JS与APP原生控件交互
"热更新"."热部署"相信对于混合式开发的童鞋一定不陌生,那么APP怎么避免每次升级都要在APP应用商店发布呢?这里就用到了混合式开发的概念,对于电商网站尤其显 ...
- Android混合开发之WebViewJavascriptBridge实现JS与java安全交互
前言: 为了加快开发效率,目前公司一些功能使用H5开发,这里难免会用到Js与Java函数互相调用的问题,这个Android是提供了原生支持的,不过存在安全隐患,今天我们来学习一种安全方式来满足Js与j ...
- Android混合开发之WebView与Javascript交互
前言: 最近公司的App为了加快开发效率选择了一部分功能采用H5开发,从目前市面的大部分App来讲,大致分成Native App.Web App.Hybrid App三种方式,个人觉得目前以Hybri ...
- EventBus实现activity跟fragment交互数据
最近老是听到技术群里面有人提出需求,activity跟fragment交互数据,或者从一个activity跳转到另外一个activity的fragment,所以我给大家介绍一个开源项目,EventBu ...
- QT5利用chromium内核与HTML页面交互
在QT5.4之前,做QT开发浏览器只能选择QWebkit,但是有过使用的都会发现,这个webkit不是出奇的慢,简直是慢的令人发指,Release模式下还行,debug下你就无语了,但是webkit毕 ...
- PHP-----文件系统的交互
本文讲解php中于文件交互中所使用的函数 代码示例 <html> <head> <title> File Detail </title> </he ...
随机推荐
- flutter中将widget转为base64
flutter中可以通过RepaintBoundary widget中的toImage方法将页面中的widget转为base64. 如何使用? 首先要在全局定义一个global key,分配给Repa ...
- hdfs数据迁移
有时候可能会进行hadoop集群数据拷贝的情况,可用以下命令进行拷贝 需要在目标集群上来进行操作 hadoop distcp hdfs://192.168.1.233:8020/user/hive/w ...
- 在EXCEL中,判断同列数据重复,并标识出来
推荐方法:建立辅助列,查找B列数据是否重复.=IF(COUNTIF(B:B,B1)>1,"重复","")按住公式单元格右下角实心十字,向下拖拽复制公式.= ...
- MySQL的几种锁机制的使用介绍
锁 在日常的开发过程中,为了控制线程的并发肯定会用到锁机制.对于数据库而言,锁机制就是数据库为了保证数据的一致性,而使各种共享资源在被并发访问变得有序所设计的一种规则.当然MySQL也不例外,根据不同 ...
- C#多线程开发-线程基础 01
最近由于工作的需要,一直在使用C#的多线程进行开发,其中也遇到了很多问题,但也都解决了.后来发觉自己对于线程的知识和运用不是很熟悉,所以将利用几篇文章来系统性的学习汇总下C#中的多线程开发. 线程基础 ...
- Servlet学习笔记(四)之请求转发与重定向(RequestDispatcher与sendRedirect)
ServletContext可以实现请求转发(ServletContext请求转发相关内容见之前博客:http://blog.csdn.net/megustas_jjc/article/details ...
- Cookie在哪里看
更多java学习请进: https://zhangjzm.gitee.io/self_study
- 动环监控系统中B接口的实现
动环监控系统简述 1.术语介绍 1.1 省集中监控中心-Province Supervision Center(PSC) 面向多FSU管理的高级监控层次,即省集中监控中心,通过开放的数据协议,连接监控 ...
- Python - 面向对象编程 - 实战(4)
需求:士兵突进 士兵许三多有一把 AK47 士兵可以开火 枪能够发射子弹 枪装填子弹,可以增加子弹数量 需求分析 很明显有两个类:士兵类,枪类 AK47 是枪名,是枪类的属性,每把枪都有子弹数,所以子 ...
- ICCV2021 | MicroNet:以极低的 FLOPs 改进图像识别
前言:这篇论文旨在以极低的计算成本解决性能大幅下降的问题.提出了微分解卷积,将卷积矩阵分解为低秩矩阵,将稀疏连接整合到卷积中.提出了一个新的动态激活函数-- Dynamic Shift Max,通过 ...