位运算很好的一个性质是可以单独每一位考虑。。。。。

题解请看: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 子序列和的异或以及异或的和的更多相关文章

  1. bzoj 4017: 小Q的无敌异或

    4017: 小Q的无敌异或 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 593  Solved: 197[Submit][Status][Discu ...

  2. BZOJ 4017 小 Q 的无敌异或 ( 树状数组、区间异或和、区间异或和之和、按位计贡献思想 )

    题目链接 题意 : 中文题 分析 : 首先引入两篇写的很好的题解 题解一.题解二 听说这种和异或相关区间求和的问题都尽量按位考虑 首先第一问.按二进制位计贡献的话.那么对于第 k 位而言 其贡献 = ...

  3. 【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 ...

  4. 【BZOJ 1770 】 [Usaco2009 Nov]lights 燈 dfs+异或方程组

    这道题明显是异或方程组,然而解不一定唯一他要的是众多解中解为1的数的最小值,这个时候我们就需要dfs了我们dfs的时候就是枚举其有不确定解的数上选0或1从而推知其他解,由于我们dfs的时候先0后1,虽 ...

  5. bzoj 2844 albus就是要第一个出场 异或和出现次数 线性基

    题目链接 题意 给定\(n\)个数,将其所有的子集(\(2^n\)个)的异或和按升序排列.给出一个询问\(q\),问\(q\)在该序列中第一次出现位置的下标(下标从\(1\)开始). 题解 结论 记其 ...

  6. 51nod 1301 集合异或和——异或dp

    题目:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1301 好题!看了TJ才会. 因为是不可重集合,所以当然有前 i 个 ...

  7. [BZOJ3261] 最大异或和 (异或前缀和,可持久化Trie)

    Description 给定一个非负整数序列{a},初始长度为N. 有M个操作,有以下两种操作类型: 1.Ax:添加操作,表示在序列末尾添加一个数x,序列的长度N+1. 2.Q l r x:询问操作, ...

  8. 51Nod 1301 集合异或和 —— 异或DP

    题目:http://www.51nod.com/onlineJudge/questionCode.html#!problemId=1301 参考博客:https://blog.csdn.net/qq_ ...

  9. AtCoder Regular Contest 098 D - Xor Sum 2 区间异或=相加 DP思想

    题意:给出n个数,求它的连续子序列中,满足下列公式,(l,r)的对数有多少对 Al xor Al+1 xor … xor Ar=Al + Al+1 + … + Ar 思路:由题意可以得到,连续子序列, ...

随机推荐

  1. iptables详细设置

    1.安装iptables防火墙 怎么知道系统是否安装了iptables?执行iptables -V,如果显示如: iptables v1.3.5 说明已经安装了iptables. 如果没有安装ipta ...

  2. C#利用System.Net发送邮件

    啥也不说了,直接上干货 using System.Net.Mail;using System.Net; //使用发送邮件的邮箱 var emailAcount = "826217795@qq ...

  3. Vue模板语法总结

    文本 数据绑定最常见的方式就是使用"Mustache"语法(两个大括号{{ }})的文本插值 <span>Message: {{ msg }}</span> ...

  4. Jenkins关联GitHub进行构建

    一.创建一个自由风格的项目 并在高级中勾选你构建完成后保存项目的路径 二.配置你存放代码的GitHub的地址并添加用户名密码 三.立即构建

  5. 好用的工具---screen命令

    问 题场景:要在服务器上配置环境,但是我的电脑无法直接连到服务器上,通常要经过好几次ssh跳转.配环境需要设置好几个用户,这自然需要同时打开好几个连 接服务器的终端窗口,每个连接到服务器的终端窗口都要 ...

  6. 29 A Quick Guide to Go's Assembler 快速指南汇编程序:使用go语言的汇编器简介

    A Quick Guide to Go's Assembler 快速指南汇编程序:使用go语言的汇编器简介 A Quick Guide to Go's Assembler Constants Symb ...

  7. activiti源码分析学习

    activiti源码分析学习导语 目前项目中用activiti来做工作流的相关工作,最近遇到一些情况下,公司二次开发的流程图渲染出现了问题,会造成流程图出不来的情况.初步分析数据库中记录以及简单的代码 ...

  8. No.13 selenium for python 单选框和复选框

    单选框 radio 点击图标,可以获取HTML中定位. 使用普通的ID定位就可以了 定位到指定元素,然后使用clicd选中即可 复选框 checkbox 勾选单个框,跟单选框一样,定位后点击就可以了 ...

  9. redis tutorail

    命令 set     get    incr expire  秒  ttl    -1 不会过期 list  : lpush  rpush  lpop  rpop   lrange   llen se ...

  10. 可怕的线程上下文类装载器(TCCL)

    在明天的 OSGi 2012 社区活动上,我将以"如何使你的类库在不依赖 OSGi 的情况下进行友好地 OSGi"为主题进行演讲.在演讲中我将会提及 Java 的线程上下文类加载器 ...