bzoj 4017 子序列和的异或以及异或的和
位运算很好的一个性质是可以单独每一位考虑。。。。。
题解请看:http://blog.csdn.net/skywalkert/article/details/45401245
对于异或的和,先枚举位,求所有异或和和中该位为1的有多少个,再乘以该位的大小(2的多少次方)。
即单独每一位考虑,每位带的权不一样。
对于和的异或,只需知道每一位中和的改位为1的奇偶性,就可以知道最终的异或值上该位是0还是1。
也是单独考虑每一位,看该位为0或1的条件。
/**************************************************************
Problem: 4017
User: idy002
Language: C++
Result: Accepted
Time:9896 ms
Memory:3544 kb
****************************************************************/ #include <cstdio>
#include <cstring>
#include <algorithm>
#define N 100010
#define Mod 998244353
using namespace std; typedef long long dnt; int n;
int aa[N]; namespace Task1 {
dnt ans;
int cnt[];
dnt mpow( dnt a, int b ) {
dnt rt;
for( rt=; b; b>>=,a=a*a%Mod )
if( b& ) rt=rt*a % Mod;
return rt;
}
void main() {
for( int b=; b<=; b++ ) {
cnt[] = cnt[] = ;
for( int i=; i<=n; i++ ) {
int bb = (aa[i]>>b)&;
int c0 = cnt[];
int c1 = cnt[];
cnt[^bb] = c0;
cnt[^bb] = c1;
cnt[bb]++;
ans = (ans+cnt[]*mpow(,b)) % Mod;
}
}
printf( "%lld ", ans );
}
};
namespace Task2 {
dnt s[N];
dnt disc[N], dtot;
int bit[][N];
dnt ans;
void init() {
memset( bit, , sizeof(bit) );
}
void modify( int bit[], int a, int delta ) { // a in [1,n]
for( int i=a; i<=dtot; i+=i&-i )
bit[i] += delta;
}
int query( int bit[], int a ) {
int rt = ;
for( int i=a; i; i-=i&-i )
rt += bit[i];
return rt;
}
void main() {
for( int i=; i<=n; i++ )
s[i] = s[i-] + aa[i];
for( int b=; b<=; b++ ) {
dnt cnt = ;
dnt mask = (1LL<<b) - ;
dtot = ;
disc[++dtot] = ;
for( int i=; i<=n; i++ )
disc[++dtot] = s[i] & mask;
sort( disc+, disc++dtot );
dtot = unique( disc+, disc++dtot ) - disc - ;
init();
modify( bit[], lower_bound(disc+,disc++dtot,)-disc, + );
for( int i=; i<=n; i++ ) {
dnt bmid = (s[i]>>b) & ;
dnt brgt = s[i] & mask;
int irgt = lower_bound( disc+, disc++dtot, brgt ) - disc;
if( bmid ) {
cnt += query( bit[], irgt );
cnt += query( bit[], dtot ) - query( bit[], irgt );
} else {
cnt += query( bit[], dtot ) - query( bit[], irgt );
cnt += query( bit[], irgt );
}
modify( bit[bmid], irgt, + );
}
ans |= (cnt&) ? (1LL<<b) : ;
}
printf( "%lld\n", ans );
}
}; int main() {
scanf( "%d", &n );
for( int i=; i<=n; i++ )
scanf( "%d", aa+i );
Task1::main();
Task2::main();
}
bzoj 4017 子序列和的异或以及异或的和的更多相关文章
- bzoj 4017: 小Q的无敌异或
4017: 小Q的无敌异或 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 593 Solved: 197[Submit][Status][Discu ...
- BZOJ 4017 小 Q 的无敌异或 ( 树状数组、区间异或和、区间异或和之和、按位计贡献思想 )
题目链接 题意 : 中文题 分析 : 首先引入两篇写的很好的题解 题解一.题解二 听说这种和异或相关区间求和的问题都尽量按位考虑 首先第一问.按二进制位计贡献的话.那么对于第 k 位而言 其贡献 = ...
- 【BZOJ 4103】 4103: [Thu Summer Camp 2015]异或运算 (可持久化Trie)
4103: [Thu Summer Camp 2015]异或运算 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 474 Solved: 258 De ...
- 【BZOJ 1770 】 [Usaco2009 Nov]lights 燈 dfs+异或方程组
这道题明显是异或方程组,然而解不一定唯一他要的是众多解中解为1的数的最小值,这个时候我们就需要dfs了我们dfs的时候就是枚举其有不确定解的数上选0或1从而推知其他解,由于我们dfs的时候先0后1,虽 ...
- bzoj 2844 albus就是要第一个出场 异或和出现次数 线性基
题目链接 题意 给定\(n\)个数,将其所有的子集(\(2^n\)个)的异或和按升序排列.给出一个询问\(q\),问\(q\)在该序列中第一次出现位置的下标(下标从\(1\)开始). 题解 结论 记其 ...
- 51nod 1301 集合异或和——异或dp
题目:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1301 好题!看了TJ才会. 因为是不可重集合,所以当然有前 i 个 ...
- [BZOJ3261] 最大异或和 (异或前缀和,可持久化Trie)
Description 给定一个非负整数序列{a},初始长度为N. 有M个操作,有以下两种操作类型: 1.Ax:添加操作,表示在序列末尾添加一个数x,序列的长度N+1. 2.Q l r x:询问操作, ...
- 51Nod 1301 集合异或和 —— 异或DP
题目:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1301 参考博客:https://blog.csdn.net/qq_ ...
- AtCoder Regular Contest 098 D - Xor Sum 2 区间异或=相加 DP思想
题意:给出n个数,求它的连续子序列中,满足下列公式,(l,r)的对数有多少对 Al xor Al+1 xor … xor Ar=Al + Al+1 + … + Ar 思路:由题意可以得到,连续子序列, ...
随机推荐
- 聊天室(下篇)GatewayWorker 与 Laravel 的整合
思路 上一篇大概梳理了一下 GatewayWorker 的基础知识.这篇就来准备整合 GatewayWorker 到 Laravel. GatewayWorker 是基于 Socket 监听的服务器框 ...
- 大数据系列之分布式计算批处理引擎MapReduce实践
关于MR的工作原理不做过多叙述,本文将对MapReduce的实例WordCount(单词计数程序)做实践,从而理解MapReduce的工作机制. WordCount: 1.应用场景,在大量文件中存储了 ...
- Windows版Oracle重建EM---备注
前提条件添加环境变量 ORACLE_HOSTNAME=<主机名:如:DESKTOP-P6J1a>ORACLE_SID=orclORACLE_UNQNAME=orcl 执行删除命令 C:\U ...
- HTML 多张图片无缝连接
<table border="0" cellspacing="0" cellpadding="0" style="heigh ...
- 洛谷P2016战略游戏
传送门啦 战略游戏这个题和保安站岗很像,这个题更简单,这个题求的是士兵人数,而保安站岗需要求最优价值. 定义状态$ f[u][0/1] $ 表示 $ u $ 这个节点不放/放士兵 根据题意,如果当前节 ...
- 使用JS实现2048小游戏
JS实现2048小游戏源码 效果图: 代码如下,复制即可使用: (适用浏览器:360.FireFox.Chrome.Opera.傲游.搜狗.世界之窗. 不支持Safari.IE8及以下浏览器.) &l ...
- vue 递归组件
如果你的项目里面的数据结构是一个树状的数据结构 然后递归组件是一个很好的一个解决你这个数据结构的一个方式 就是组件内部调用自身 tree.vue里面直接tree-node <tree-node& ...
- ROS数据可视化工具Rviz和三维物理引擎机器人仿真工具V-rep Morse Gazebo Webots USARSimRos等概述
ROS数据可视化工具Rviz和三维物理引擎机器人仿真工具V-rep Morse Gazebo Webots USARSimRos等概述 Rviz Rviz是ROS数据可视化工具,可以将类似字符串文本等 ...
- 利用sql server直接创建日历
看到网上有高手直接用sql查询创建日历,也想自己动手实践一遍.笔者这里的实现和网上的都没有什么区别,思路也没有什么新意.觉得好玩,就把它记下来吧. 一.准备知识1.sql的with关键字关于with和 ...
- mybatis中多条件判断---choose when的用法
<select id="getFunctionByPage" resultMap="FunctionRlt"> SELECT K.FUNCTION_ ...