codeforces1451 E. Bitwise Queries(位运算妙用)

E1. Bitwise Queries (Easy Version)

a+b=(a&b)+(a∣b)a+b=(a\&b)+(a|b)a+b=(a&b)+(ab)
根据上述式子用333次$&和333∣|操作求出a1+a2,a2+a3,a1+a3a_1+a_2,a_2+a_3,a_1+a_3a1+a2,a2+a3,a1+a3由此得出a1,a2,a3a_1,a_2,a_3a1,a2,a3
根据a1⊕ai=xa_1\oplus a_i=xa1ai=x于是ai=x⊕a1a_i=x\oplus a_1ai=xa1可使用n−3n-3n3⊕\oplus操作得出答案
共计n+3n+3n+3次。。。
大佬题解
a+b=(a⊕b)+2×(a&b)a+b=(a\oplus b)+2×(a\&b)a+b=(ab)+2×(a&b)
如果已知a1⊕a2,a2⊕a3a_1\oplus a_2,a_2 \oplus a_3a1a2,a2a3那么a1⊕a3=(a1⊕a2)⊕(a2⊕a3)a_1\oplus a_3=(a_1\oplus a_2)\oplus (a_2\oplus a_3)a1a3=(a1a2)(a2a3)
那么只需用555次就可以知道a1,a2,a3a_1,a_2,a_3a1,a2,a3最终用n+2n+2n+2次得出答案。

#define IO ios::sync_with_stdio(false);cin.tie();cout.tie(0)
#pragma GCC optimize(2)
#include<set>
#include<map>
#include<cmath>
#include<stack>
#include<queue>
#include<random>
#include<bitset>
#include<string>
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<unordered_map>
#include<unordered_set>
using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
const int mod=998244353;
const int N=100010;
int x,y,z;
void prework()
{int ab1,ab2,ac1,ac2,bc1,bc2;printf("XOR 1 2\n");fflush(stdout);cin>>ab1;printf("AND 1 2\n");fflush(stdout);cin>>ab2;printf("XOR 1 3\n");fflush(stdout);cin>>ac1;printf("AND 1 3\n");fflush(stdout);cin>>ac2;bc1 = ab1 ^ ac1;printf("AND 2 3\n");fflush(stdout);cin>>bc2;x=ab1+2*ab2;y=ac1+2*ac2;z=bc1+2*bc2;
}
int main()
{IO;int T=1;//cin>>T;while(T--){int n;cin>>n;vector<int> ans(n+1);prework();ans[1]=(x+y-z)/2;ans[2]=(x+z-y)/2;ans[3]=(y+z-x)/2;for(int i=4;i<=n;i++){int tmp;printf("XOR 1 %d\n",i);fflush(stdout);cin>>tmp;ans[i]=tmp^ans[1];}cout<<"! ";for(int i=1;i<=n;i++) cout<<ans[i]<<' ';cout<<'\n';}return 0;
}

E2. Bitwise Queries (Hard Version)

大佬题解
同样只要我们能确认一个值,其余的值都能通过异或来得到。由此我们目标是确定一个值。

注意到0<xi<n−10<x_i<n-10<xi<n1,由此数组有两种情况

  • 数组元素不重复,各不相同
  • 数组元素重复

①对于数组元素重复的情况,我们首先进行n−1n-1n1x1⊕xix_1\oplus x_ix1xi将异或值记入数组aia_iai,不难发现其中肯定存在相同的值,只要记录相同值的位置i,ji,ji,j那么只需要进行一次xi&xjx_i\&x_jxi&xj即可知道xix_ixixjx_jxj,那么就能根据aia_iai或者aja_jaj得出x1x_1x1进而得出答案。操作nnn
②如果不存在那么一定有某个数与第一个数相差1,ai=1a_i=1ai=1,即xi⊕x1=1x_i\oplus x_1=1xix1=1,于是 不难得知x1x_1x1xix_ixi分别是(x1&xi)(x_1\& x_i)(x1&xi)(x1&xi)⊕1(x_1\& x_i)\oplus1(x1&xi)1
然后随便找一个与第一个数奇偶性相同的数(ai&1=0a_i\&1=0ai&1=0)用一次&\&&操作x1&xix_1\&x_ix1&xi的奇偶性即是x1x_1x1的奇偶性,于是可以得出x1x_1x1。操作n+1n+1n+1

#define IO ios::sync_with_stdio(false);cin.tie();cout.tie(0)
#pragma GCC optimize(2)
#include<set>
#include<map>
#include<cmath>
#include<stack>
#include<queue>
#include<random>
#include<bitset>
#include<string>
#include<vector>
#include<cstdio>
#include<cstring>
#include<iostream>
#include<algorithm>
#include<unordered_map>
#include<unordered_set>
using namespace std;
typedef long long ll;
typedef pair<int,int> pii;
const int mod=998244353;
const int N=200010;
int a[N];
map<int,int> pos;
int main()
{//IO;int T=1;//cin>>T;while(T--){int n;cin>>n;pos.clear();pos[0]=1;int k=0,v;for(int i=2;i<=n;i++){printf("XOR 1 %d\n",i);fflush(stdout);cin>>a[i];if(pos[a[i]]&&!k){printf("AND %d %d\n",pos[a[i]],i);fflush(stdout);cin>>v;k=i;}pos[a[i]]=i;}if(k) a[1]=a[k]^v;else{printf("AND 1 %d\n",pos[1]);fflush(stdout);cin>>a[1];for(auto t:pos){if((t.first&1)||t.second==1) continue;printf("AND 1 %d\n",t.second);fflush(stdout);int c; cin>>c;if(c&1) a[1]^=1;break;}}cout<<"! "<<a[1]<<' ';for(int i=2;i<=n;i++) cout<<(a[i]^a[1])<<' ';cout<<'\n';}return 0;
}

要加油哦~

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/319230.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

P4240-毒瘤之神的考验【莫比乌斯反演,平衡规划】

正题 题目链接:https://www.luogu.com.cn/problem/P4240 题目大意 QQQ组数据给出n,mn,mn,m求 ∑i1n∑j1mφ(ij)\sum_{i1}^n\sum_{j1}^m\varphi(i\times j)i1∑n​j1∑m​φ(ij) 1≤Q≤104,1≤n,m≤1051\leq Q\leq 10^4,1\leq n,m\leq 10^51≤Q≤104,1≤n,m≤105 解题思路 首先…

【最小生成树】水箱(P5952)

正题 P5952 题目大意 有一个n*m的网格&#xff0c;每个网格之间有一个板&#xff0c;给出每个板的高度&#xff08;边界有一个高度为 ∞\infty∞ 的墙&#xff09;&#xff0c;在每个网格中注水&#xff08;必须是非负整数&#xff09;&#xff0c;使得两个高度不等且相邻的网…

2020牛客国庆集训派对day4 Jokewithpermutation

Jokewithpermutation 题目描述 Joey had saved a permutation of integers from 1 to n in a text file. All the numbers were written as decimal numbers without leading spaces. Then Joe made a practical joke on her: he removed all the spaces in the file. Help Jo…

.NET Core使用IO合并技巧轻松实现千万级消息推送

之前讲述过多路复用实现单服百万级别RPS吞吐,但在文中有一点是没有说的就是消息IO合并&#xff0c;如果缺少了消息IO合并即使怎样多路复用也很难达到百万级别的请求响毕竟所有应用层面的网络IO读写都是非常损耗性能的&#xff08;需要硬件配置很高的服务器&#xff09;。这一章…

codeforces1457 C. Bouncing Ball

写这个题写了1h&#xff0c;赛后无意看见jly神的代码只能膜拜%%% C. Bouncing Ball 预处理从1→k1\to k1→k开始跳需要添加多少个平台&#xff0c;预处从k1→nk1\to nk1→n这些不难发现由于每次跳k格&#xff0c;只需要利用前缀和思想和前面预处理的结果即可做差求出。 然后枚…

P4491-[HAOI2018]染色【二项式反演,NTT】

正题 题目链接:https://www.luogu.com.cn/problem/P4491 题目大意 给nnn个物品染上mmm种颜色&#xff0c;若恰好有kkk个颜色的物品个数为SSS那么就会产生WkW_kWk​的贡献。求所有染色方案的贡献和 1≤n≤107,1≤m≤105,1≤S≤1501\leq n\leq 10^7,1\leq m\leq 10^5,1\leq S\l…

【传递闭包】【倍增】幸福路径(P4308)

正题 P4308 题目大意 给一个图&#xff0c;每个点有一个权值 axa_xax​&#xff0c;当你经过一条边时体力p\times pp&#xff08;体力初始为1&#xff09;&#xff0c;每到一个点造成的贡献为体力ax\times a_xax​&#xff0c;问最大贡献&#xff08;路径可能是无限长的&…

天气情况图像分类练习赛 第三阶段(赛中感)

第三阶段也是实战阶段&#xff0c;不同于前两个阶段的填空而是实打实的预测分析 题目会给出8000张照片数据&#xff0c;其中6000作为训练集而另外2000张作位测试集&#xff0c;通过对6000张的训练来预测2000的结果&#xff0c;并将结果输出到csv文件中&#xff0c;提交检验成功…

一码阻塞,万码等待:ASP.NET Core 同步方法调用异步方法“死锁”的真相

在我们 2015 年开始的从 .NET Framework 向 .NET Core 迁移的工程中&#xff0c;遇到的最大的坑就是标题中所说的——同步方法中调用异步方法发生”死锁”。虽然在 .NET Framework 时代就知道不能在同步方法中调用异步方法&#xff0c;但我们却明知路有坑&#xff0c;偏向此路行…

codeforces1456 D. XOR-gun

D. XOR-gun 大佬题解 当n比较大的时候&#xff0c;一定有连续相同的3个数最高位都是1&#xff0c;只需要将这三个数其中两个异或一次即可满足题意只需要操作1次。 当n比较小时可以直接暴力&#xff0c;不难发现异或操作要么是一段区间异或然后与区间端点相邻的比较O(n2)O(n^2…

AT4119-[ARC096C]Everything on It【斯特林数,容斥】

正题 题目链接:https://www.luogu.com.cn/problem/AT4119 题目大意 一个集合S{k∈[1,n]∪N}S\{k\in[1,n]\cup N\}S{k∈[1,n]∪N}&#xff0c;它的所有子集作为元素组成的集合中要求满足每一个数字的出现之和不小于222&#xff0c;求方案数对PPP取模。 1≤n≤3000,P∈[108,109…

【交互】【随机】Lost Root(CF1061F)

正题 luogu CF1061F 题目大意 给出n和k&#xff0c;现在有一颗n个点的满k叉树&#xff0c;每次查询可以问一个点是否在另外两个点的路径上&#xff0c;让你在 60n60\times n60n 次询问内得到根节点 解题思路 因为是满k叉数&#xff0c;可以先得到深度dep 每次随机找两个点&…

take

take 题解参考 题目描述 Kanade has n boxes , the i-th box has p[i] probability to have an diamond of d[i] size. At the beginning , Kanade has a diamond of 0 size. She will open the boxes from 1-st to n-th. When she open a box,if there is a diamond in it an…

将传统 ASP.NET 应用迁移到 .NET Core

点击蓝字关注我现在越来越多的人在谈论. NET Core。诚然&#xff0c;.NET Core 是未来, 但是.NET Framework 仍在支持, 因为大量的应用程序无法在短时间内迁移。.NET Core 和 .NET Framework 就像电动汽车和汽油动力汽车。汽油车是成熟的&#xff0c;你可以毫无任何问题驾驶它&…

CF932G-Palindrome Partition【PAM】

正题 题目链接:https://www.luogu.com.cn/problem/CF932G 题目大意 给出一个长度为nnn的字符串&#xff0c;将其分为kkk段&#xff08;kkk为任意偶数&#xff09;&#xff0c;记为ppp。要求满足对于任意iii都有pipk−i1p_ip_{k-i1}pi​pk−i1​。求方案数。 1≤n≤1061\leq n…

2018 ACM ICPC Asia Regional - Seoul B.Cosmetic Survey

参考大佬代码 题目大意 nnn个顾客&#xff0c;mmm种画妆品&#xff0c;每一个顾客会给mmm种化妆品一个值&#xff0c;这个值代表这个化妆品在他心中的排名&#xff0c;排名越小越喜欢&#xff0c;如果这个值为0说明最不喜欢这一种化妆品&#xff08;值为0理解为无穷大&#xf…

The table(CF226D)

正题 CF226D 题目大意 给一个n*m的矩阵&#xff0c;每次操作可以使一行或一列全部变号&#xff08;变-&#xff0c;-变&#xff09;&#xff0c;问如何操作可以使所有行列之和都是正数 解题思路 考虑每次暴力找小于0的一行或一列&#xff0c;然后反转 因为每次反转肯定会使…

[翻译] 初看 ASP.NET Core 3.0 即将到来的变化

原文: A first look at changes coming in ASP.NET Core 3.0在我们努力完成下一个 minor 版本的 ASP.NET Core 的同时&#xff0c;我们也在对下一个 major 版本进行更新&#xff0c;其中包括如何使用框架组合项目、更紧密的 .NET Core 集成以及第三方开源集成&#xff0c;所有这…

数字串

来源&#xff1a;牛客网&#xff1a; 题目描述 一个只含数字的字符串&#xff0c;q次操作&#xff0c;每次操作将第i位数字改为x&#xff0c;每次操作后&#xff0c;统计长度在[l, r]之间且首数字大于尾数字的子串的个数。 输入描述: 第一行一个只含数字的字符串&#xff1b…

【随机】Kuroni and the Punishment(CF1305F)

正题 luogu CF1305F 题目大意 给你n个数&#xff0c;每次操作可以使一个数1或-1&#xff0c;让你用最小的操作数使所有数的gcd>1 解题思路 显然把所有数都修改为偶数可以得到 2|gcd&#xff0c;且步数 ≤n\leq n≤n 对于其它方案&#xff0c;至少有一半的数修改次数小于…