博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
BZOJ4017 小Q的无敌异或 好题
阅读量:4697 次
发布时间:2019-06-09

本文共 1434 字,大约阅读时间需要 4 分钟。

给一个序列

询问这个序列

1:所有子区间的异或值的和

2:所有子区间的和的异或值

第一个操作,拆二进制位,枚举右端点r,记录这个位前r个数字0/1的个数,右端点转移O(1)

第二个操作比较复杂,对于每个右端点要询问sum[r]-sum[l-1]mod(2^(k+1))>=2^k的左端点个数(的奇偶性)

题解用了树状数组维护,参考,题解里对于模不等式的解释很巧妙,复习的时候多看看吧

#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
#include
using namespace std;#define ll long long#define ull unsigned long long#define pb push_back#define mem(a) memset(a,0,sizeof a)#define FOR(a) for(int i=1;i<=a;i++) const int inf =0x3f3f3f3f; const int maxn=1e5+7;const int mod=998244353;int n;int a[maxn],x[maxn],bit[maxn],ans1;ll s[maxn],p[maxn],ans2;void inc(int &x,int y){ x+=y;if(x>=mod)x-=mod;}void add(int x){ for(;x<=n;x+=~x&x+1) bit[x]^=1;}int sum(int x){ int ret=0; for(;x>=0;x-=~x&x+1) ret^=bit[x]; return ret;}int idx(ll val){ //return lower_bound(p,p+n,val)-p; int L=-1,R=n; while(L
>1; if(p[M]<=val)L=M; else R=M-1; } return L; }int main(){ scanf("%d",&n); for(int i=1;i<=n;i++){ scanf("%d",&a[i]); x[i]=x[i-1]^a[i]; s[i]=s[i-1]+a[i]; } //异或的和 for(int k=0,powk=1;k<30;++k,inc(powk,powk)){ //枚举指数 int cnt[2]={},tmp=0; for(int i=0;i<=n;i++){ inc(tmp,cnt[((x[i]>>k)&1)^1]); ++cnt[(x[i]>>k)&1]; } inc(ans1,1ll*powk*tmp%mod); } //和的异或 for(int k=0;(1ll<
<=s[n];++k){ int tmp=0; for(int i=0;i<=n;i++){ p[i]=s[i]&((1ll<

转载于:https://www.cnblogs.com/Drenight/p/8611225.html

你可能感兴趣的文章
批处理文件中的路径问题
查看>>
hibernate出现No row with the given identifier exists问题
查看>>
为什么wait()和notify()属于Object类
查看>>
配置NRPE的通讯
查看>>
shp系列(一)——利用C++进行shp文件的读(打开)与写(创建)开言
查看>>
匹配两个空格之间的字符。。。
查看>>
CSS 文字溢出 变成省略号 ...
查看>>
Spring事务
查看>>
java编程基础(三)流程控制语句
查看>>
让数据库跑的更快的7个MySQL优化建议
查看>>
jquery 取id模糊查询
查看>>
解决在vue中,自用mask模态框出来后,下层的元素依旧可以滑动的问题
查看>>
修改node节点名称
查看>>
PAT(B) 1014 福尔摩斯的约会(Java)
查看>>
PAT甲级题解-1123. Is It a Complete AVL Tree (30)-AVL树+满二叉树
查看>>
项目开发总结报告(GB8567——88)
查看>>
SSH加固
查看>>
端口扫描base
查看>>
iOS IM开发的一些开源、框架和教程等资料
查看>>
FansUnion:共同写博客计划终究还是“流产”了
查看>>