每一位维护一颗线段树

(-1)^1 =-2

(-2)^1=-1

#include <cstdio>
#include<iostream>
using namespace std;
//#define int long long
#define si signed
#define sc(x) scanf("%d", &x);
#define P pair<int, int>
int lazy[][];
int sum[][];
int A[];
int n, m;
void pushdown(int id, int x, int l, int r)
{
if (lazy[id][x] == )
{
lazy[id][x] = ;
int mid = l + r >> ;
lazy[id][x << ] ^= ;
sum[id][x << ] = (mid - l + ) - sum[id][x << ];
lazy[id][x << | ] ^= ;
sum[id][x << | ] = (r - mid) - sum[id][x << | ];
}
else if (lazy[id][x] == -)
{
lazy[id][x] = ;
int mid = l + r >> ;
lazy[id][x << ] = -;
sum[id][x << ] = (mid - l + );
lazy[id][x << | ] = -;
sum[id][x << | ] = (r - mid);
}
else if (lazy[id][x] == -)
{
lazy[id][x] = ;
int mid = l + r >> ;
lazy[id][x << ] = -;
sum[id][x << ] = ;
lazy[id][x << | ] = -;
sum[id][x << | ] = ;
}
}
void pushup(int id, int x)
{
sum[id][x] = sum[id][x << ] + sum[id][x << | ];
}
void build(int id, int l, int r, int x)
{
lazy[id][x] = ;
if (l == r)
{
sum[id][x] = ((A[l] >> id) & );
return;
}
int mid = (l + r) / ;
build(id, l, mid, x << );
build(id, mid + , r, x << | );
pushup(id, x);
}
void update(int id, int l, int r, int x, int type, int L, int R)
{
if (type == )
{
// cout<<type<<"type"<<endl; if (l >= L && r <= R)
{
lazy[id][x] ^= ;
sum[id][x] = (r - l + ) - sum[id][x];
//cout<<L<<' '<<R<<endl;
return;
}
pushdown(id, x, l, r);
int mid = (l + r) >> ;
if (L <= mid)
update(id, l, mid, x << , type, L, R);
if (R > mid)
update(id, mid + , r, x << | , type, L, R);
pushup(id, x);
}
else if (type == )
{ if (l >= L && r <= R)
{
lazy[id][x] = -;
sum[id][x] = ;
return;
}
pushdown(id, x, l, r);
int mid = (l + r) >> ;
if (L <= mid)
update(id, l, mid, x << , type, L, R);
if (R > mid)
update(id, mid + , r, x << | , type, L, R);
pushup(id, x);
}
else
{ if (l >= L && r <= R)
{
lazy[id][x] = -;
sum[id][x] = r - l + ;
return;
}
pushdown(id, x, l, r);
int mid = (l + r) >> ;
if (L <= mid)
update(id, l, mid, x << , type, L, R);
if (R > mid)
update(id, mid + , r, x << | , type, L, R);
pushup(id, x);
}
}
int query(int id, int l, int r, int x, int L, int R)
{
int ans = ;
if (L <= l && r <= R)
{
return sum[id][x];
}
pushdown(id, x, l, r);
int mid = l + r >> ;
if (L <= mid)
ans += query(id, l, mid, x << , L, R);
if (R > mid)
ans += query(id, mid + , r, x << | , L, R);
return ans;
}
si main()
{
int T;
sc(T)
string s;
while (T--)
{
sc(n) sc(m);
for (int i = ; i <= n; i++)
sc(A[i])
for (int i = ; i <; i++)
{
build(i, , n-, );
} int l,r,x;
while (m--)
{
cin >> s;
if (s[] == 'S')
{
sc(l) sc(r)
int ans=;
for(int i=;i<;i++){
ans +=query(i,,n-,,l,r)*(<<i);
}
cout<<ans<<'\n';
}
else if (s[] == 'X')
{
sc(x)
sc(l) sc(r) for(int i=;i<;i++){
if((x>>i)&){
update(i,,n-,,,l,r);
}
}
}
else if (s[] == 'O')
{
sc(x)
sc(l) sc(r) for(int i=;i<;i++){
if((x>>i)&){
update(i,,n-,,,l,r);
}
}
}
else
{
sc(x)
sc(l) sc(r) for(int i=;i<;i++){
if(!((x>>i)&)){
update(i,,n-,,,l,r);
}
}
}
}
} //system("pause");
}

xor or and 线段树的更多相关文章

  1. luogu P2574 XOR的艺术 (线段树)

    luogu P2574 XOR的艺术 (线段树) 算是比较简单的线段树. 当区间修改时.\(1 xor 1 = 0,0 xor 1 = 1\)所以就是区间元素个数减去以前的\(1\)的个数就是现在\( ...

  2. codeforces 22E XOR on Segment 线段树

    题目链接: http://codeforces.com/problemset/problem/242/E E. XOR on Segment time limit per test 4 seconds ...

  3. Codeforces Round #149 (Div. 2) E. XOR on Segment (线段树成段更新+二进制)

    题目链接:http://codeforces.com/problemset/problem/242/E 给你n个数,m个操作,操作1是查询l到r之间的和,操作2是将l到r之间的每个数xor与x. 这题 ...

  4. codeforces 242E. XOR on Segment 线段树

    题目链接 给n个数, 两种操作, 一种是求区间内的数的和, 一种是将区间内的数异或x. 异或x没有什么思路, 单个异或肯定超时, 区间异或也没有办法做....后来才知道可以按位建线段树, 这样建20棵 ...

  5. 洛谷 P2574 XOR的艺术(线段树 区间异或 区间求和)

    To 洛谷.2574 XOR的艺术 题目描述 AKN觉得第一题太水了,不屑于写第一题,所以他又玩起了新的游戏.在游戏中,他发现,这个游戏的伤害计算有一个规律,规律如下 1. 拥有一个伤害串为长度为n的 ...

  6. 2018.08.22 hyc的xor/mex(线段树/01trie)

    hyc的xor/mex 描述 NOIP2017就要来了,备战太累,不如做做hyc的新题? 找回自信吧! 一句话题意:n个数,m个操作 操作具体来讲分两步 1.读入x,把n个数全部xor上x 2.询问当 ...

  7. XOR on segment(线段树区间异或更新)

    原题传送门 本题大意:给定n个数字和m个操作,操作共有两种,第一种是求解区间l到r上元素的和,第二种是将区间l到r的元素都异或一个x,作为某个位置的新值. 很容易想到线段树维护区间和,但是我们发现,在 ...

  8. 「 Luogu P2574 」 XOR的艺术——线段树

    # 解题思路 这题不难,但是原谅我一开始的傻逼想法,一会儿再给大家透露透露. 先说怎么做这题. 显然对于 $0$ 和 $1$ 来说,异或无非也就只有两种变化 异或了奇数次,$0$ 就会变成 $1$,$ ...

  9. CodeForces 242E - XOR on Segment 二维线段树?

    今天练习赛的题....又是线段树的变换..拿到题我就敲了个点更新区间查询的..果断超时...然后想到了可以将每个数与合表示成不进位的二进制数..这样就可以区间进行更新了..比赛的时候写搓了..刚重写了 ...

随机推荐

  1. PAT B1021 个位数统计 (15)

    AC代码 #include <cstdio> #include <iostream> #include <cstring> using namespace std; ...

  2. python网络爬虫(2)回顾Python编程

    文件写入 def storFile(data,fileName,method='a'): with open(fileName,method,newline ='') as f: f.write(da ...

  3. C++ 类学习笔记 :: 作用域限定符

    类与封装的概念: 1.类: 类的实现.类的使用. 当使用类的时候,不需要关心实现的细节.当创建类的时候,才需要考虑到内部具体的实现细节. 2.类的封装: 成员变量,C++用于表示属性的变量. 成员函数 ...

  4. C#实现Web链接启动应用程序

    C#实现Web链接启动应用程序 最近需要配合Web端实现用户点击链接来启动应用程序并且需要能够传参数给应用程序. 那么就可以使用注册表来实现这个功能 编写注册表可以在软件安装程序中加入,也可以在软件启 ...

  5. check cve

    今天想检查一下 Gitlab 11.9.0 产品受哪些 cve 的影响.其实网上已经有很多网站可以查询产品的相关 cve,但就是粒度比较粗.我想在 cve 列表中筛选出特定的版本,已经特定的版本,比如 ...

  6. 帝国cms 项目搬家换域名修改详情页图片路径

    update phome_ecms_news_data_1 set newstext=REPLACE (newstext,'/d/file/','http://www.xxxx.com/d/file/ ...

  7. IE6兼容笔记

    1.IE6中,元素右浮动的时候前面不能有文本或内联元素,否则会换行独占一行 解决办法:将浮动元素放到文本或内联元素前面,大都在制作新闻列表的时候会遇到这种问题. 未完,待续!

  8. vue.js(1)--创建vue实例的基本结构

    vue实例基本结构与MVVM框架 (1)vue实例基本结构 <!DOCTYPE html> <html lang="en"> <head> &l ...

  9. jquery preventDefault() 方法防止打开不是本站的链接URL

    将以下代码保存为test.html,用浏览器打开即可测试 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN&q ...

  10. 用PS修改PNG格式图标的颜色

    需求:将黑色的PNG格式图标,更改为其它颜色 原始图标:   原始图标 - 黑色   方法1: 图层样式 -> 颜色叠加     选择颜色叠加     选择想要的颜色   方法2: 更换颜色 一 ...