bzoj3687 简单题 bitset
来源:互联网 发布:gbic端口 编辑:程序博客网 时间:2024/05/15 02:19
这道题一开始表示一脸懵逼,题意虽简短但都反应了一会儿.从异或的性质可知,一个数异或他自己是等于0的,所以一个数如果出现了偶数次的话,那就相当于0.凑成子集i的方案总数设为dp[i],那么
dp[i+a[j]]+=dp[i],一个简单的背包.
因为只用判断奇偶,奇数为1,偶数为0,我们用bitset来进行位运算,第i位表示子集i**出现次数**是奇还是偶.我们把之前整个bitset向左移a[j]位,因为第i为表示子集i,所以第i位向左移a[j]位到i+a[j]位相当于就完成了背包问题加法的过程(见上方dp转移),因为是整个bitset,那就相当于所有的子集都加上了a[j],这里就大大优化了效率.我们再跟移之前的bitset相异或.
分类讨论来理解一下为什么要异或.如果原来位i(子集i出现次数)是奇,你现在bitset中某个数加上a[j]又凑成子集i,那么就变成偶,1^1=0,原来是0(即为偶),现在凑成一个就变成奇,0^1=1.原来也没有现在也没有凑成,0^0=0;十分的巧妙.
#include<stdio.h>#include<bitset>using namespace std;const int maxn=2000000;bitset<maxn> a;int sum,n,ans,x;int main(){ scanf("%d",&n),a[0]=1; for(register int i=1;i<=n;i++){ scanf("%d",&x); a^=a<<x; sum+=x; } for(register int i=1;i<=sum;i++) if(a[i]) ans^=i; printf("%d",ans);}
阅读全文
0 0
- 【bzoj3687】 简单题 bitset
- 【bzoj3687】【简单题】【bitset】
- 【BZOJ3687】简单题【bitset】
- [BZOJ3687][简单题][Bitset]
- bzoj3687简单题 bitset
- [bzoj3687]简单题 bitset
- bzoj3687 简单题 bitset
- 【bzoj3687】【简单题】bitset
- 【bitset乱搞】BZOJ3687 简单题
- [bzoj3687]简单题(bitset)
- BZOJ3687 简单题 解题报告 【递推】【bitset】
- BZOJ3687【bitset】
- 【BZOJ3687】简单题
- bzoj3687: 简单题
- BZOJ3687:简单题
- [bzoj3687]简单题
- bzoj3687 简单题
- bzoj3687 -- bitset优化DP
- 支持向量机
- JSP_strut2架构下前台接收后台传递到前台之数据并处理以使用的一种方法
- ios AudioUnit bluetooth 录音 播放 实现
- 二维指针*(void **)的研究(uC/OS-II案例)
- 【JZOJ5219】【GDOI2018模拟7.10】B
- bzoj3687 简单题 bitset
- json 学习日记
- PHP explode 和 implode 用法
- Physically Based Rendering
- win10系统打字卡顿
- 文章标题
- 批处理bat修改文件后缀
- 五分钟学GIS | GIS服务器集群技术
- 南阳理工学院ACM完全覆盖