xor or and 线段树
每一位维护一颗线段树
(-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 线段树的更多相关文章
- luogu P2574 XOR的艺术 (线段树)
luogu P2574 XOR的艺术 (线段树) 算是比较简单的线段树. 当区间修改时.\(1 xor 1 = 0,0 xor 1 = 1\)所以就是区间元素个数减去以前的\(1\)的个数就是现在\( ...
- codeforces 22E XOR on Segment 线段树
题目链接: http://codeforces.com/problemset/problem/242/E E. XOR on Segment time limit per test 4 seconds ...
- 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. 这题 ...
- codeforces 242E. XOR on Segment 线段树
题目链接 给n个数, 两种操作, 一种是求区间内的数的和, 一种是将区间内的数异或x. 异或x没有什么思路, 单个异或肯定超时, 区间异或也没有办法做....后来才知道可以按位建线段树, 这样建20棵 ...
- 洛谷 P2574 XOR的艺术(线段树 区间异或 区间求和)
To 洛谷.2574 XOR的艺术 题目描述 AKN觉得第一题太水了,不屑于写第一题,所以他又玩起了新的游戏.在游戏中,他发现,这个游戏的伤害计算有一个规律,规律如下 1. 拥有一个伤害串为长度为n的 ...
- 2018.08.22 hyc的xor/mex(线段树/01trie)
hyc的xor/mex 描述 NOIP2017就要来了,备战太累,不如做做hyc的新题? 找回自信吧! 一句话题意:n个数,m个操作 操作具体来讲分两步 1.读入x,把n个数全部xor上x 2.询问当 ...
- XOR on segment(线段树区间异或更新)
原题传送门 本题大意:给定n个数字和m个操作,操作共有两种,第一种是求解区间l到r上元素的和,第二种是将区间l到r的元素都异或一个x,作为某个位置的新值. 很容易想到线段树维护区间和,但是我们发现,在 ...
- 「 Luogu P2574 」 XOR的艺术——线段树
# 解题思路 这题不难,但是原谅我一开始的傻逼想法,一会儿再给大家透露透露. 先说怎么做这题. 显然对于 $0$ 和 $1$ 来说,异或无非也就只有两种变化 异或了奇数次,$0$ 就会变成 $1$,$ ...
- CodeForces 242E - XOR on Segment 二维线段树?
今天练习赛的题....又是线段树的变换..拿到题我就敲了个点更新区间查询的..果断超时...然后想到了可以将每个数与合表示成不进位的二进制数..这样就可以区间进行更新了..比赛的时候写搓了..刚重写了 ...
随机推荐
- Websocket --(2)实现
首先声明,本篇博文参考文章 https://blog.csdn.net/jack_eusong/article/details/79064081 主要在于理解和自己动手搭建环境,自己搭建的过程中会发生 ...
- 死磕并发之CountDownLatch解析
CountDownLatch解析 CountDownLatch是什么 CountDownLatch是基于AQS的阻塞工具,阻塞一个或者多个线程,直到所有的线程都执行完成. CountDownLatch ...
- Luogu P3959 [NOIP2017]宝藏
题目 STO rqy OTZ 首先这种题一看我们就知道可以爆搜. prim一眼假了,但是加个SA也能过. 所以我们来写状压. 记\(f_{i,j,S}\)表示起点到\(j\)距离为\(i\),我们现在 ...
- 八、break和continue
- Git 生成.gitinore忽略文件
Git 生成.gitinore忽略文件 CD到指定目录下: touch .gitinore .gitinore忽略文件 三种方法: # 以'#'开始的行,被视为注释.(#是注释的意思) # 忽略掉所 ...
- roll out项目中原系统自定义程序不能编辑
1.SE38编辑时报 程序源系统与现阶段系统不一致:Carry out repairs in non-original systems only if urgent 2.SE16N 查看表TADIR, ...
- python变量、对象和引用你真的明白了吗
python变量.对象和引用你真的明白了吗 变量.对象和引用 Python不像C++,Java等语言一样,他们可以不用事先声明变量类型而直接对变量进行赋值.对Python语言来讲,对象的类型和内存都是 ...
- random 方法 生成随机数
Math.random() 生成 大于等于0.0 且小于 1.0 的double 型随机数 ( 0.0 <= Math.random() < 1.0 ) 可以使用它便携简单了表达式,生成任 ...
- python-函数4(递归、高阶函数)
python-函数4(递归.高阶函数) 递归 在函数内部,可以调用其他函数.如果一个函数在内部调用自身本身,这个函数就是递归函数. 递归特性: 1. 递归必须有一个明确的结束条件 2. 每次进入更深一 ...
- Linux20期学习笔记 Day1
Linux就该这么学第一章 1.4重置root管理员密码 放到红帽RHCSA考前辅导视频 源代码安装: 弊端:(好处第二章讲解) 1.难度高,安装困难 2.自己解决依赖关系(暂时不说) 新技术:RP ...