链接: http://acm.hdu.edu.cn/showproblem.php?pid=3949

题意:

给出n个数,从中任意取几个数字异或,求第k小的异或和

思路:

线性基求第k小异或和,因为题目中可以出现异或和为0的情况,但线性基里是不会出现异或和为0的情况,所以我们需要多处理下,将数字全插入到线性基中,如果无法插入也就代表会出现异或和为0的情况,那么求第k小就应该变成求线性基中第k-1小。

实现代码:

  1. #include<bits/stdc++.h>
  2. using namespace std;
  3. #define ll long long
  4. const int M = 1e6+;
  5. struct Linear_Basis{
  6. ll b[],nb[],tot;
  7. bool flag = ;
  8. void init(){
  9. flag = ; tot = ;
  10. memset(b,-,sizeof(b));
  11. memset(nb,,sizeof(nb));
  12. }
  13.  
  14. void Insert(ll x){
  15. for(int i = ;i >= ;i --){
  16. if(x&(1LL<<i)){
  17. if(b[i] == -){
  18. b[i] = x;
  19. return ;
  20. }
  21. x ^= b[i];
  22. }
  23. }
  24. flag = ;
  25. return ;
  26. }
  27.  
  28. ll Max(ll x){
  29. ll ret = x;
  30. for(int i = ;i >= ;i --)
  31. ret = max(ret,ret^b[i]);
  32. return ret;
  33. }
  34.  
  35. ll Min(ll x){
  36. ll ret = x;
  37. for(int i = ;i <= ;i ++)
  38. if(b[i]) ret ^= b[i];
  39. return ret;
  40. }
  41.  
  42. void rebuild(){
  43. for(int i = ;i >= ;i --){
  44. if(b[i] == -) continue;
  45. for(int j = i-;j >= ;j --){
  46. if(b[j] == -) continue;
  47. if(b[i]&(1LL<<j)) b[i]^=b[j];
  48. }
  49. }
  50. for(int i = ;i <= ;i ++)
  51. if(b[i]!=-) nb[tot++] = b[i];
  52. }
  53.  
  54. ll K_Min(ll k){
  55. ll res = ;
  56. if(flag == ) k --;
  57. if(k == ) return ;
  58. if(k >= (1LL<<tot))
  59. return -;
  60. for(int i = ;i >= ;i --)
  61. if(k&(1LL<<i))
  62. res ^= nb[i];
  63. return res;
  64. }
  65. }LB;
  66.  
  67. int main()
  68. {
  69. int cas = ,t,n,m;
  70. cin>>t;
  71. while(t--){
  72. LB.init();
  73. cin>>n;
  74. ll x;
  75. for(int i = ;i <= n;i ++){
  76. cin>>x;
  77. LB.Insert(x);
  78. }
  79. LB.rebuild();
  80. printf("Case #%d:\n",cas++);
  81. scanf("%d",&m);
  82. while(m--){
  83. ll k;
  84. scanf("%lld",&k);
  85. printf("%lld\n",LB.K_Min(k));
  86. }
  87. }
  88. return ;
  89. }

hdu 3949 XOR (线性基)的更多相关文章

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

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

  2. HDU 3949 XOR 线性基

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

  3. hdu 3949 XOR 线性基 第k小异或和

    题目链接 题意 给定\(n\)个数,对其每一个子集计算异或和,求第\(k\)小的异或和. 思路 先求得线性基. 同上题,转化为求其线性基的子集的第k小异或和. 结论 记\(n\)个数的线性基为向量组\ ...

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

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

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

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

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

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

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

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

  8. ACM学习历程—HDU 3949 XOR(xor高斯消元)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=3949 题目大意是给n个数,然后随便取几个数求xor和,求第k小的.(重复不计算) 首先想把所有xor的 ...

  9. Xor && 线性基练习

    #include <cstdio> #include <cstring> ; ; int cnt,Ans,b,x,n; inline int Max(int x,int y) ...

随机推荐

  1. day88

    ContentType 场景需求:比方说我们现有两种商品,但是他们对应着一个价格策略表,为了防止数据库的浪费,我们在价格策略中加入一个表名字段,一个表明对应的id字段,这样的设计既优化了数据库,还不怕 ...

  2. 搭建mysql cluster

    虚拟机搭建Mysql Cluster 参考文档:http://www.cnblogs.com/jackluo/archive/2013/01/19/2868152.html http://www.cn ...

  3. spring boot + dubbo开发遇到过的异常

    异常信息 NoClassDefFoundErrororg.apache.zookeeper.ClientCnxn$SendThread.run(ClientCnxn.java:1162) Sessio ...

  4. JavaScript 格式化数字 - 转

    function number_format(number, decimals, dec_point, thousands_sep,roundtag) { /* * 参数说明: * number:要格 ...

  5. 使用Python遇到:'utf-8' codec can't decode byte 0x8b in position 1: invalid start byte 问题

    查看你的HTTP头部是否有如下头部信息:"Accept-Encoding": "gzip, deflate" 这条信息代表本地可以接收压缩格式的数据,而服务器在 ...

  6. CF [2016-2017 ACM-ICPC CHINA-Final][GYM 101194 H] Great Cells

    很久以前做的一道思博题了,今天来补一补. 大致题意:在一个\(n*m\)的矩阵内填整数,数字在\([1,k]\)范围内.矩阵中某格的数为great number当且仅当与它同行同列的数字都严格比它小. ...

  7. 安装Visual Studio2013

    安装Visual Studio2013现在官网下载在选择安装的可选功能这里,大家可以根据自己需要勾选,也可以默认全选.这里有个小功能,把鼠标放在文字上,会弹出各个功能的详细描述.选择四个常用的功能,另 ...

  8. Flask之WSGI:Werkzeug

    WSGI 一个Web应用的本质就是: 浏览器发送一个HTTP请求: 服务器收到请求,生成一个HTML文档: 服务器把HTML文档作为HTTP响应的Body发送给浏览器: 浏览器收到HTTP响应,从HT ...

  9. 复审Partner

    复审代码后,发现了一些问题: 首先说优点:代码十分工整,很清晰,各种类易于理解,逻辑上很通顺. 基本实现了代码功能,输出正确. 发现的缺点:对于文件后缀的识别有点问题,不能识别所需求的所有文件,只有一 ...

  10. 【SE】Week17 : 软件工程课程总结

    软工课程总结  总算结束了一个学期大部分的事情,可以静下心来写篇软工的总结了. 在本学期的软工课程中,我担任的角色是Chronos团队的PM兼开发人员.在课程之前,我认为PM的角色应该还蛮轻松的,无非 ...