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 思路:由题意可以得到,连续子序列, ...
随机推荐
- Servlet笔记5--设置欢迎页面及HTTP状态码404、500
欢迎页面: 代码详解: web.xml配置文件: <?xml version="1.0" encoding="UTF-8"?> <web-ap ...
- Spring4笔记4--基于XML的DI(依赖注入)
基于XML的DI(依赖注入): Bean 实例在调用无参构造器创建了空值对象后,就要对 Bean 对象的属性进行初始化.初始化是由容器自动完成的,称为注入.根据注入方式的不同,常用的有两类:设值注入. ...
- Linux SSH Backdoor分析排查
1.SSH后门分类 SSH后门方式有以下几种 软链接 SSH Server wrapper SSH Keylogger 2.软链接 利用方法 [root@helen]# ln -sf /usr/sbi ...
- css-css背景
CSS 允许应用纯色作为背景,也允许使用背景图像创建相当复杂的效果 一:背景色background-color 属性 p {background-color: gray;} 二:背景图像 backgr ...
- day05作业
一.1.switch 2.字符串 3.表达式1 4.break 5.continue 二.1.B 2.A 3.BD 4.D 5.B 6.B 7.A 8.D 9.D 10.B 三.1.√ 2.√ 3.× ...
- 函数fgets和fputs、fread和fwrite用法小结(转)
字符串读写函数fgets和fputs: 1.fgets()函数:原型char *fgets(char *s, int n, FILE *stream);从流中读取n-1(n默认1024)个字符之前,如 ...
- 判断一个字符是否为数字的两种方法(C/C++)
在平时,我们经常遇见判断字符是否为数字这种题目,虽然感觉还是很简单,不过我是个更喜欢用函数的人,因为我觉得这样更便捷,所以我更推荐第二种方式. 1.直接判断 #include <stdio.h& ...
- Owin 自定义中间件(2)中间件进阶
前面一篇文章简单的介绍了中间件的应用 下面编写一个自定义的中间件类库,并加入中间件参数以及引入日志记录中间件的异常 下面来看下中间件的构造,参数可以自定义 这里我定义了一个参数类 编写中间件需要引入 ...
- CF 586A 找1的个数和101的个数
Sample test(s) input 50 1 0 1 1 output 4 input 71 0 1 0 0 1 0 output 4 input 10 output 0 # include & ...
- Android 客户端 okhttp3 与服务器之间的双向验证
[原文]https://blog.csdn.net/leng_wen_rou/article/details/58596142 本篇是Android 客户端基于okhttp3的网络框架 和后台服务器之 ...