题意:给你一个集合,让你构造一个长度尽量长的排列,使得排列中任意相邻两个位置的数XOR后是集合中的数。

思路:我们考虑枚举i, 然后判断集合中所有小于1 << i的数是否可以构成一组异或空间的基,如果可以就可以通过深搜构造出来。判断的方法是通过高斯消元。找到最大的i,我们通过深搜的方式构造答案,深搜的时候通过枚举作为基的集合中的数来确定,这样相邻两个数之间的异或值一定是集合中的数。

标程中的找异或空间的算法有点奇特,先记录一下:

维护一个集合basis,是已经找到的基,加入一个新的数(x)时,在basis中从大到小,执行x = min(x, x ^ v) (v是basis中的元素),如果最后x不是0,那么x就是一个基底,插入basis。

代码:

#include<bits/stdc++.h>
using namespace std;
const int maxn = 200010;
const int maxm = 2000010;
vector<int> ans, vec;
set<int> basis;
set<int> ::iterator it;
int ed;
bool v[maxm];
int a[maxn];
void add(int x) {//高斯消元
int tmp = x;
if(basis.size()) {
for (it = --basis.end();; it--) {
tmp = min(tmp, tmp ^ (*it));
if(it == basis.begin()) break;
}
}
if(!tmp) return;
basis.insert(tmp);
vec.push_back(x);
} void dfs(int x, int deep = 1) {
v[x] = 1;
ans.push_back(x);
if(deep == (1 << ed)) return;
for (int i = 0; i < vec.size(); i++) {
if(!v[x ^ vec[i]]) {
dfs(x ^ vec[i], deep + 1);
return;
}
}
} int main() {
int n;
scanf("%d", &n);
for (int i = 1; i <= n; i++) {
scanf("%d", &a[i]);
}
sort(a + 1, a + 1 + n);
int pos = 1;
ed = 0;
for (int i = 1; i < 20; i++) {
for (; pos <= n && a[pos] < (1 << i); pos++)
add(a[pos]);
if(basis.size() == i) {
ed = i;
}
}
basis.clear();
vec.clear();
for (int i = 1; i <= n && a[i] < (1 << ed); i++)
add(a[i]);
dfs(0);
printf("%d\n", ed);
for (int i = 0; i < ans.size(); i++)
printf("%d ", ans[i]);
}

  

最新文章

  1. CF724B. Batch Sort[枚举]
  2. [ZT]Language codes – MFC
  3. VS2013中Python学习笔记[Django Web的第一个网页]
  4. PHP 7問世,2億網站效能翻倍有望
  5. Linux svn 回滚版本库
  6. C# Winform中WndProc 函数作用
  7. 短小实用 渗透用的Python小脚本
  8. jQuery实现图片轮播
  9. 查看uCOS-II的CPU使用率
  10. 关于新的man版本出现“无法解析 /usr/share/man/zh_CN/man1/ls.1.gz: 没有那个文件或目录“
  11. Quartz 多个触发器
  12. 在ASP.NET MVC中对手机号码的验证
  13. PHPCMS收集标签使用
  14. IOS算法(三)之插入排序
  15. c语言中细节注意(初级)
  16. 初体验GCP,【福利300$试用金】
  17. 深入浅出JWT(JSON Web Token )
  18. 使用Redis 计数器防止刷接口
  19. 【iOS地图开发】巧妙打造中英文全球地图
  20. 【java规则引擎】《Drools7.0.0.Final规则引擎教程》第4章 4.3 日历

热门文章

  1. 最大公因数数gcd模板
  2. [HTML知识体系]语义化标签概论
  3. CentOS 7 virtualenv创建python3与python2的环境&amp;&amp;运行项目
  4. 调试Spark应用
  5. 怀旧浪潮来袭,小霸王游戏、windows95......曾经的经典哪些能戳中你的心怀?
  6. shell cut从一个文件中提取列
  7. JavaScript设计模式小抄集(持续更新)
  8. Springboot项目静态资源配置
  9. SCP-Py-002
  10. error LNK2001: 无法解析的外部符号 __imp__Shell_NotifyIconA@8