【题目描述】

  给定n个非负整数A[1], A[2], ……, A[n]。

  对于每对(i, j)满足1 <= i < j <= n,得到一个新的数A[i] xor A[j],这样共有n*(n-1)/2个新的数。求这些数(不包含A[i])中前k小的数。

  注:xor对应于pascal中的“xor”,C++中的“^”。

【输入格式】

  第一行2个正整数 n,k,如题所述。

  以下n行,每行一个非负整数表示A[i]。

【输出格式】

  共一行k个数,表示前k小的数。

【样例输入】

4 5

1

1

3

4

【样例输出】

0 2 2 5 5

【样例解释】

  1 xor 1 = 0 (A[1] xor A[2])

  1 xor 3 = 2 (A[1] xor A[3])

  1 xor 4 = 5 (A[1] xor A[4])

  1 xor 3 = 2 (A[2] xor A[3])

  1 xor 4 = 5 (A[2] xor A[4])

  3 xor 4 = 7 (A[3] xor A[4])

  前5小的数:0 2 2 5 5

【数据范围】

  第一个数据点,n <= 1000;

  第二个数据点,k = 1;

  对于40%的数据,n <= 10000; k <= 10;

  对于60%的数据,n <= 20000;

  对于100%的数据,2 <= n <= 100000; 1 <= k <= min{250000, n*(n-1)/2};0 <= A[i] < 2^31

Solution

  由于出题人数据是随机生成的就卡不掉我的暴力骗分啦~不过我是构了一组。

  很明显,a-b<=a^b<=a+b

  先对A[]排序,选取k个可能成为答案的数,用堆或者线段树维护修改和查询。当插进去的数比当前堆中的最大数还大的话就break。

 #include<cstdio>
#include<cstring>
#include<cstdlib>
#include<ctime>
int main()
{
freopen("xorit.in","w",stdout);
srand(time());
int n=,m=,mod=<<;mod--;
printf("%d %d\n",n,m);
for(int i=;i<=n;i++)printf("%d ",rand());
}

Data Maker

 #include<cstdio>
#include<algorithm>
#include<cstring>
int t[],d,n,k,a[],tmp;
int main()
{
scanf("%d%d",&n,&k);int i,j,l;
memset(t,,sizeof(t));
for(d=;d<k;d<<=);
for(i=;i<=n;i++)scanf("%d",&a[i]);
std::sort(a+,a++n);
for(i=;i<=n;i++)
for(j=i-;j;j--)t[++tmp]=a[i]^a[j];
std::sort(t+,t++tmp);
for(i=;i<=k;i++)printf("%d ",t[i]);
}

暴力

 #include<cstdio>
#include<algorithm>
#include<cstring>
int t[],d,n,k,a[],cnt,tmp,now;
int main()
{
scanf("%d%d",&n,&k);int i,j,l,o;k++;
for(d=;d<k;d<<=);
for(i=;i<=n;i++)scanf("%d",&a[i]);
std::sort(a+,a++n);
for(i=;i<=n;i++)
for(j=i-;j;j--)
{
tmp=a[i]^a[j];now=;
for(l=k+d-;l;l>>=)now<t[l]?now=t[l]:;
if(now==&&cnt==k)break;
if(cnt<k)
{
if(now<tmp)now=tmp;
for(t[l=d+cnt]=tmp,cnt++,l>>=;l;l>>=)
{
tmp=t[l<<]>t[l<<|]?t[l<<]:t[l<<|];
t[l]=tmp;
}
}
else
{
if(tmp>=now&&a[i]-a[j]>now)break;
if(tmp<now)
{
for(o=;o<d;t[o<<|]==now?o=o<<|:o<<=);
if(now<tmp)now=tmp;
for(t[o]=tmp,o>>=;o;o>>=)
{
tmp=t[o<<]>t[o<<|]?t[o<<]:t[o<<|];
t[o]=tmp;
}
}
}
}
std::sort(t+d,t+d+k);k--;
for(i=d;i<d+k;i++)printf("%d ",t[i]);
}

std

另外还有一种二进制分组的做法。考虑在二进制中前k位相同的数,k+1位对答案的贡献为cnt[0]*cnt[1],cnt[i]表示k+1位为i的数。

于是我们可以找到第k小的答案范围,然后暴力就行了。复杂度O(nlogn)

还有一种可持久化Trie树的做法--详见Noi超级钢琴

[FJSC2014]异或之的更多相关文章

  1. [BZOJ3696][FJSC2014]化合物(异或规则下的母函数)

    题目:http://hzwer.com/3708.html 分析: 类似树分治思想,设f[x][i]表示以x为根的子树的所有点中,与x的距离为i的点有多少个,这个可以预处理出来 然后我们考虑每颗子树对 ...

  2. Android数据加密之异或加密算法

    前言: 这几天被公司临时拉到去做Android IM即时通信协议实现,大致看了下他们定的协议,由于之前没有参与,据说因服务器性能限制,只达成非明文传递,具体原因我不太清楚,不过这里用的加密方式是采用异 ...

  3. Oracle数据库异机升级

    环境: A机:RHEL5.5 + Oracle 10.2.0.4 B机:RHEL5.5 需求: A机10.2.0.4数据库,在B机升级到11.2.0.4,应用最新PSU补丁程序. 目录: 一. 确认是 ...

  4. [LeetCode] Maximum XOR of Two Numbers in an Array 数组中异或值最大的两个数字

    Given a non-empty array of numbers, a0, a1, a2, … , an-1, where 0 ≤ ai < 231. Find the maximum re ...

  5. [PHP][位转换积累]之异或运算的简单加密应用

    异或的符号是^.按位异或运算, 对等长二进制模式按位或二进制数的每一位执行逻辑按位异或操作. 操作的结果是如果某位不同则该位为1, 否则该位为0. xor运算的逆运算是它本身,也就是说两次异或同一个数 ...

  6. Poj The xor-longest Path 经典题 Trie求n个数中任意两个异或最大值

    Time Limit: 2000MS   Memory Limit: 65536K Total Submissions: 5646   Accepted: 1226 Description In an ...

  7. RMAN异机恢复遭遇ORA-01547、ORA-01152、ORA-01110错误案例

    测试环境:     操作系统  :  Red Hat Enterprise Linux ES release 4 (Nahant Update 4)   VMWARE     数据库     :  O ...

  8. RAC异机恢复

    RAC异机恢复PDCL到PFCL: PNCL:RAC+ASM ,product env   db name:PNCL   instance:PDCL1 PDCL2 PFCL:RAC+ASM ,perf ...

  9. BZOJ 3261: 最大异或和

    Description 一个序列,支持两个操作. 1.在序列尾加入一个数. 2.询问 [l,r] 中与 x 异或值最大的数. \(n\leqslant 3*10^5\) Sol 可持久化 Trie 树 ...

随机推荐

  1. C#发送邮件-C#教程

    如何利用C#实现邮件发送功能?闲话不多说请看代码: public static void SendMail(MyEmail email){//发送验证邮箱邮件.//1.创建邮件MailMessage ...

  2. HTML5吧

    一.为了能使IE9以下的IE浏览器也能支持html5的标签,所以首先得在文档头部用条件注释的方法引入那段著名的代码. 1 2 3 <!--[if lt IE 9]> <script ...

  3. [弹出消息] C#ShowMessageBox帮助类

    点击下载 ShowMessage.rar 看下面代码吧 /// <summary> /// 类说明:Assistant /// 编 码 人:苏飞 /// 联系方式:361983679 // ...

  4. 简单登录案例(SharedPreferences存储账户信息)&联网请求图片并下载到SD卡(文件外部存储)

    新人刚学习Android两周,写一个随笔算是对两周学习成果的巩固,不足之处欢迎各位建议和完善. 这次写的是一个简单登录案例,大概功能如下: 注册的账户信息用SharedPreferences存储: 登 ...

  5. ios 将状态栏改为白色方法!

    1在Info.plist中设置UIViewControllerBasedStatusBarAppearance 为NO2 在需要改变状态栏颜色的ViewController中在ViewDidLoad方 ...

  6. prmopt 提示框接收字符串,输入后按确定弹出警告框,警告内容为逆序的字符串

    虽然已经找到offer,但因为公司还没安排实习,所以在学校的时间多了很多.好吧,这段时间我用来备考四级啦(好悲催,还没过),然后这一天,闲着无聊,就帮妹妹看了这样子一道题目啦. 题目内容: 编制一个从 ...

  7. [学习笔记]设计模式之Decorator

    写在前面 为方便读者,本文已添加至索引: 设计模式 学习笔记索引 Decorator(装饰)模式,可以动态地给一个对象添加一些额外的职能.为了更好地理解这个模式,我们将时间线拉回Bridge模式笔记的 ...

  8. Android 中LinearLayout控件属性

    id             为控件指定相应的ID        text           指定控件当中显示的文字,需要注意的是,这里尽量使用strings.xml文件当中的字符        g ...

  9. 前端开发web组件之旅(一)-- 定义与加载组件

    /* 前言 */ 自上而下的 职责和API应用层框架层框架浏览器 一 组件定义与调用 1.增加一个组件 tabview.css ------------------------------------ ...

  10. Java反射结合JDBC写的一个通用DAO

    以前写反射只是用在了与设计模式的结合上,并没有考虑到反射可以与DAO结合.也是一个偶然的机会,被正在上培训的老师点到这个问题,才考虑到这个可能性,于是上网参考各种代码,然后自己动手开发了一个通用DAO ...