题目链接

题意

给定\(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. C - K-inversions URAL - 1523 (dp + 线段树)

    题目链接:https://cn.vjudge.net/contest/275079#problem/C 具体思路:我们可以分层的去建立,假设我们要找k层,我们可以先把满足1.2....k-1层的满足情 ...

  2. D - Frog and Portal (利用斐波那契数列的性质)

    题目链接:https://cn.vjudge.net/contest/270201#problem/D 具体思路:利用斐波那契数列的性质,斐波那契数列可以构成任何正整数,所以按照顺序减下去肯定能减到0 ...

  3. Tensorflow中使用TFRecords高效读取数据--结合Attention-over-Attention Neural Network for Reading Comprehension

    原文链接:https://arxiv.org/pdf/1607.04423.pdf 本片论文主要讲了Attention Model在完形填空类的阅读理解上的应用. 转载:https://blog.cs ...

  4. 宋牧春: Linux设备树文件结构与解析深度分析(1) 【转】

    转自:https://mp.weixin.qq.com/s/OX-aXd5MYlE_YoZ3p32qWA 作者简介 宋牧春,linux内核爱好者,喜欢阅读各种开源代码(uboot.linux.ucos ...

  5. kernel随机生成MAC地址的接口

    /**  * eth_random_addr - Generate software assigned random Ethernet address * @addr: Pointer to a si ...

  6. c json实战引擎六 , 感觉还行

    前言 看到六, 自然有 一二三四五 ... 为什么还要写呢.  可能是它还需要活着 : ) 挣扎升级中 . c json 上面代码也存在于下面项目中(维护的最及时) structc json 这次版本 ...

  7. springBoot单元测试-模拟MVC测试

    1)模拟mvc测试,和基础测试是一样的, 都需要在pom文件中引入junit的支持. 略 2)编写测试类 Application1TestMVC 在类头上除啦加入之前的@RunWith(SpringR ...

  8. 一键去除网页BOM属性【解决乱码,头部空白,&#65279问题】

    几个常出现的问题: 1.网站打开空白 2.页面头部出现多余的空白 3.网站出现乱码,如“锘�” 解决方法可以是: 1.选用专业的编辑器,例如notepad++,sublime,editplus这样不会 ...

  9. Python抓取微博评论(二)

    对于新浪微博评论的抓取,首篇做的时候有些考虑不周,然后现在改正了一些地方,因为有人问,抓取评论的时候“爬前50页的热评,或者最新评论里的前100页“,这样的数据看了看,好像每条微博的评论都只能抓取到前 ...

  10. 当想把html element里面的text提取出来可以试着用正则

    var a='123<span>456</span><span class="active">789</span>'; a.repl ...