题目链接

题意

给定\(n\)个数,对其每一个子集计算异或和,求第\(k\)小的异或和。

思路

先求得线性基。

同上题,转化为求其线性基的子集的第k小异或和

结论

记\(n\)个数的线性基为向量组\(B=\{b_0,b_1,b_2,...,b_t\}(有b_i[p_i]=1,p_1\lt p_2\lt ...\lt p_t)\),记\(k\)的二进制表示为向量\(\vec{K}\).

则第\(k\)小异或和为$$\oplus_{\vec{K}[i]=1}b_i$$

即\(k\)的二进制表示中为\(1\)的那些位所对应的线性基中的向量异或起来的值。

正确性证明

对于任意的\(1\leq i\lt j\leq tot(tot\)为子集的总个数,也即异或和的总个数)

记\(i\)的二进制表示为\(\vec{I}\),\(j\)的二进制表示为\(\vec{J}\),设从高到低的\(\vec{I}\)与\(\vec{J}\)第一个不同的位为第\(pos\)位,因为\(i\lt j\),故有\(\vec{I}[pos]=0, \vec{J}[pos]=1\).

记第\(i\)小异或值为\(ii\),第\(j\)小异或值为\(jj\),对应的向量分别为\(\vec{II}, \vec{JJ}\). 根据上述构造第\(k\)小值的方法,构造\(\vec{II}\)时没有异或\(b_{pos}\),而构造\(\vec{JJ}\)时异或了\(b_{pos}\). 又由线性基的性质,只有\(b_{pos}[p_{pos}]=1\),故有\(\vec{II}[p_{pos}]=0, \vec{JJ}[p_{pos}]=1\).

即\(\vec{II}\)与\(\vec{JJ}\)高位都相同,第\(p_{pos}\)位\(\vec{JJ}\)大,故\(\vec{II}\lt \vec{JJ}\),即\(ii\lt jj\).

所以\(i\lt j\rightarrow ii\lt jj\),所以\(rank(i)=rank(ii)\),得到了一一对应的关系,故构造的正确性得证。

注意点

如果原\(n\)个数表示成的\(01\)串线性相关,那么除了可以用线性基线性组合而得的\(2^r-1\)个数外,另有最小的异或和为\(0\).

Code

#include <bits/stdc++.h>
#define maxl 60
#define LL long long
using namespace std;
struct LinearBasis {
LL a[maxl+1]; bool rel; int sz;
vector<LL> v;
LinearBasis() { memset(a, 0, sizeof a); rel = false; sz = 0; v.clear();}
void insert(LL t) {
for (int i = maxl; i >= 0; --i) {
if (!(t >> i & 1)) continue;
if (a[i]) t ^= a[i];
else {
for (int j = 0; j < i; ++j) if (t >> j & 1) t ^= a[j];
for (int j = i+1; j <= maxl; ++j) if (a[j] >> i & 1) a[j] ^= t;
a[i] = t, ++sz;
return;
}
}
rel = true;
}
void basis() {
for (int i = 0; i <= maxl; ++i) if (a[i]) v.push_back(a[i]);
}
LL kth(LL x) {
LL ret = 0;
for (int i = 0; i < v.size(); ++i) if (x >> i & 1) ret ^= v[i];
return ret;
}
};
int kas;
void work() {
int n, q; LL x;
scanf("%d", &n);
LinearBasis lb;
for (int i = 0; i < n; ++i) {
scanf("%lld", &x);
lb.insert(x);
}
lb.basis(); scanf("%d", &q);
printf("Case #%d:\n", ++kas); LL tot = (1LL << lb.sz) - 1;
for (int i = 0; i < q; ++i) {
scanf("%lld", &x);
if (lb.rel) --x;
if (x > tot) puts("-1");
else printf("%lld\n", lb.kth(x));
}
}
int main() {
int T;
scanf("%d", &T);
while (T--) work();
return 0;
}

hdu 3949 XOR 线性基 第k小异或和的更多相关文章

  1. hdu 3949 XOR (线性基)

    链接: http://acm.hdu.edu.cn/showproblem.php?pid=3949 题意: 给出n个数,从中任意取几个数字异或,求第k小的异或和 思路: 线性基求第k小异或和,因为题 ...

  2. HDU 3949 XOR [线性基|高斯消元]

    目录 题目链接 题解 代码 题目链接 HDU 3949 XOR 题解 hdu3949XOR 搞死消元找到一组线性无关组 消出对角矩阵后 对于k二进制拆分 对于每列只有有一个1的,显然可以用k的二进制数 ...

  3. HDU 3949 XOR 线性基

    http://acm.hdu.edu.cn/showproblem.php?pid=3949 求异或第k小,结论是第k小就是 k二进制的第i位为1就把i位的线性基异或上去. 但是这道题和上一道线性基不 ...

  4. HDU3949 XOR(线性基第k小)

    Problem Description XOR is a kind of bit operator, we define that as follow: for two binary base num ...

  5. HDU 3949 XOR (线性基第k小)题解

    题意: 给出\(n\)个数,求出子集异或第\(k\)小的值,不存在输出-1. 思路: 先用线性基存所有的子集,然后对线性基每一位进行消元,保证只有\(d[i]\)的\(i\)位存在1,那么这样变成了一 ...

  6. HDU 3949 XOR ——线形基 高斯消元

    [题目分析] 异或空间的K小值. 高斯消元和动态维护线形基两种方法都试了试. 动态维护更好些,也更快(QAQ,我要高斯消元有何用) 高斯消元可以用来开拓视野. 注意0和-1的情况 [代码] 高斯消元 ...

  7. HDU3949 XOR (线性基)

    HDU3949 XOR Problem Description XOR is a kind of bit operator, we define that as follow: for two bin ...

  8. HDU 3949 XOR(高斯消元搞基)

    HDU 3949 XOR pid=3949" target="_blank" style="">题目链接 题意:给定一些数字,问任取几个异或值第 ...

  9. HDU 3949 XOR [高斯消元XOR 线性基]

    3949冰上走 题意: 给你 N个数,从中取出若干个进行异或运算 , 求最后所有可以得到的异或结果中的第k小值 N个数高斯消元求出线性基后,设秩为$r$,那么总共可以组成$2^r$中数字(本题不能不选 ...

随机推荐

  1. 【CodeForces】679 B. Bear and Tower of Cubes

    [题目]B. Bear and Tower of Cubes [题意]有若干积木体积为1^3,2^3,...k^3,对于一个总体积X要求每次贪心地取<=X的最大积木拼上去(每个只能取一次)最后总 ...

  2. UVA - 10494 If We Were a Child Again

    用java写的大数基本操作,java要求的格式比较严谨. import java.util.*; import java.math.*; public class Main { public stat ...

  3. Discrete Logging(POJ2417 + BSGS)

    题目链接:http://poj.org/problem?id=2417 题目: 题意: 求一个最小的x满足a^x==b(mod p),p为质数. 思路: BSGS板子题,推荐一篇好的BSGS和扩展BS ...

  4. koa源码阅读[0]

    koa源码阅读[0] Node.js也是写了两三年的时间了,刚开始学习Node的时候,hello world就是创建一个HttpServer,后来在工作中也是经历过Express.Koa1.x.Koa ...

  5. DNSLOG在渗透测试中的玩法儿

    首先了解一下DNS是啥??? DNS(Domain Name System,域名系统),万维网上作为域名和IP地址相互映射的一个分布式数据库,能够使用户更方便的访问互联网,而不用去记住能够被机器直接读 ...

  6. thinkphp对数据库的增删改查(查询构造器)

  7. Battery Charging Specification 1.2 中文详解 来源:www.chengxuyuans.com

    1. Introduction 1.1 Scope 规范定义了设备通过USB端口充电的检测.控制和报告机制,这些机制是USB2.0规范的扩展,用于专用 充电器(DCP).主机(SDP).hub(SDP ...

  8. juery给所有ID属性相同的div绑定一个事件

    案例: <div id="div1">内容</div> <div id="div1">内容</div> < ...

  9. 码源中国.gitignore忽略文件配置

    码源中国.gitignore忽略文件配置 ## Ignore Visual Studio temporary files, build results, and ## files generated ...

  10. openjudge-NOI 2.6-2985 数字组合

    题目链接:http://noi.openjudge.cn/ch0206/2985/ 题解: 跟背包问题有点相似,暂且算背包型DP吧,虽然是一道递推题…… fj表示和为j时的结果,得: 即为j减去每一个 ...