每一位维护一颗线段树

(-1)^1 =-2

(-2)^1=-1

  1. #include <cstdio>
  2. #include<iostream>
  3. using namespace std;
  4. //#define int long long
  5. #define si signed
  6. #define sc(x) scanf("%d", &x);
  7. #define P pair<int, int>
  8. int lazy[][];
  9. int sum[][];
  10. int A[];
  11. int n, m;
  12. void pushdown(int id, int x, int l, int r)
  13. {
  14. if (lazy[id][x] == )
  15. {
  16. lazy[id][x] = ;
  17. int mid = l + r >> ;
  18. lazy[id][x << ] ^= ;
  19. sum[id][x << ] = (mid - l + ) - sum[id][x << ];
  20. lazy[id][x << | ] ^= ;
  21. sum[id][x << | ] = (r - mid) - sum[id][x << | ];
  22. }
  23. else if (lazy[id][x] == -)
  24. {
  25. lazy[id][x] = ;
  26. int mid = l + r >> ;
  27. lazy[id][x << ] = -;
  28. sum[id][x << ] = (mid - l + );
  29. lazy[id][x << | ] = -;
  30. sum[id][x << | ] = (r - mid);
  31. }
  32. else if (lazy[id][x] == -)
  33. {
  34. lazy[id][x] = ;
  35. int mid = l + r >> ;
  36. lazy[id][x << ] = -;
  37. sum[id][x << ] = ;
  38. lazy[id][x << | ] = -;
  39. sum[id][x << | ] = ;
  40. }
  41. }
  42. void pushup(int id, int x)
  43. {
  44. sum[id][x] = sum[id][x << ] + sum[id][x << | ];
  45. }
  46. void build(int id, int l, int r, int x)
  47. {
  48. lazy[id][x] = ;
  49. if (l == r)
  50. {
  51. sum[id][x] = ((A[l] >> id) & );
  52. return;
  53. }
  54. int mid = (l + r) / ;
  55. build(id, l, mid, x << );
  56. build(id, mid + , r, x << | );
  57. pushup(id, x);
  58. }
  59. void update(int id, int l, int r, int x, int type, int L, int R)
  60. {
  61. if (type == )
  62. {
  63. // cout<<type<<"type"<<endl;
  64.  
  65. if (l >= L && r <= R)
  66. {
  67. lazy[id][x] ^= ;
  68. sum[id][x] = (r - l + ) - sum[id][x];
  69. //cout<<L<<' '<<R<<endl;
  70. return;
  71. }
  72. pushdown(id, x, l, r);
  73. int mid = (l + r) >> ;
  74. if (L <= mid)
  75. update(id, l, mid, x << , type, L, R);
  76. if (R > mid)
  77. update(id, mid + , r, x << | , type, L, R);
  78. pushup(id, x);
  79. }
  80. else if (type == )
  81. {
  82.  
  83. if (l >= L && r <= R)
  84. {
  85. lazy[id][x] = -;
  86. sum[id][x] = ;
  87. return;
  88. }
  89. pushdown(id, x, l, r);
  90. int mid = (l + r) >> ;
  91. if (L <= mid)
  92. update(id, l, mid, x << , type, L, R);
  93. if (R > mid)
  94. update(id, mid + , r, x << | , type, L, R);
  95. pushup(id, x);
  96. }
  97. else
  98. {
  99.  
  100. if (l >= L && r <= R)
  101. {
  102. lazy[id][x] = -;
  103. sum[id][x] = r - l + ;
  104. return;
  105. }
  106. pushdown(id, x, l, r);
  107. int mid = (l + r) >> ;
  108. if (L <= mid)
  109. update(id, l, mid, x << , type, L, R);
  110. if (R > mid)
  111. update(id, mid + , r, x << | , type, L, R);
  112. pushup(id, x);
  113. }
  114. }
  115. int query(int id, int l, int r, int x, int L, int R)
  116. {
  117. int ans = ;
  118. if (L <= l && r <= R)
  119. {
  120. return sum[id][x];
  121. }
  122. pushdown(id, x, l, r);
  123. int mid = l + r >> ;
  124. if (L <= mid)
  125. ans += query(id, l, mid, x << , L, R);
  126. if (R > mid)
  127. ans += query(id, mid + , r, x << | , L, R);
  128. return ans;
  129. }
  130. si main()
  131. {
  132. int T;
  133. sc(T)
  134. string s;
  135. while (T--)
  136. {
  137. sc(n) sc(m);
  138. for (int i = ; i <= n; i++)
  139. sc(A[i])
  140. for (int i = ; i <; i++)
  141. {
  142. build(i, , n-, );
  143. }
  144.  
  145. int l,r,x;
  146. while (m--)
  147. {
  148. cin >> s;
  149. if (s[] == 'S')
  150. {
  151. sc(l) sc(r)
  152. int ans=;
  153. for(int i=;i<;i++){
  154. ans +=query(i,,n-,,l,r)*(<<i);
  155. }
  156. cout<<ans<<'\n';
  157. }
  158. else if (s[] == 'X')
  159. {
  160. sc(x)
  161. sc(l) sc(r)
  162.  
  163. for(int i=;i<;i++){
  164. if((x>>i)&){
  165. update(i,,n-,,,l,r);
  166. }
  167. }
  168. }
  169. else if (s[] == 'O')
  170. {
  171. sc(x)
  172. sc(l) sc(r)
  173.  
  174. for(int i=;i<;i++){
  175. if((x>>i)&){
  176. update(i,,n-,,,l,r);
  177. }
  178. }
  179. }
  180. else
  181. {
  182. sc(x)
  183. sc(l) sc(r)
  184.  
  185. for(int i=;i<;i++){
  186. if(!((x>>i)&)){
  187. update(i,,n-,,,l,r);
  188. }
  189. }
  190. }
  191. }
  192. }
  193.  
  194. //system("pause");
  195. }

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. Websocket --(2)实现

    首先声明,本篇博文参考文章 https://blog.csdn.net/jack_eusong/article/details/79064081 主要在于理解和自己动手搭建环境,自己搭建的过程中会发生 ...

  2. 死磕并发之CountDownLatch解析

    CountDownLatch解析 CountDownLatch是什么 CountDownLatch是基于AQS的阻塞工具,阻塞一个或者多个线程,直到所有的线程都执行完成. CountDownLatch ...

  3. Luogu P3959 [NOIP2017]宝藏

    题目 STO rqy OTZ 首先这种题一看我们就知道可以爆搜. prim一眼假了,但是加个SA也能过. 所以我们来写状压. 记\(f_{i,j,S}\)表示起点到\(j\)距离为\(i\),我们现在 ...

  4. 八、break和continue

  5. Git 生成.gitinore忽略文件

    Git  生成.gitinore忽略文件 CD到指定目录下: touch .gitinore .gitinore忽略文件 三种方法: # 以'#'开始的行,被视为注释.(#是注释的意思) # 忽略掉所 ...

  6. roll out项目中原系统自定义程序不能编辑

    1.SE38编辑时报 程序源系统与现阶段系统不一致:Carry out repairs in non-original systems only if urgent 2.SE16N 查看表TADIR, ...

  7. python变量、对象和引用你真的明白了吗

    python变量.对象和引用你真的明白了吗 变量.对象和引用 Python不像C++,Java等语言一样,他们可以不用事先声明变量类型而直接对变量进行赋值.对Python语言来讲,对象的类型和内存都是 ...

  8. random 方法 生成随机数

    Math.random() 生成 大于等于0.0 且小于 1.0 的double 型随机数 ( 0.0 <= Math.random() < 1.0 ) 可以使用它便携简单了表达式,生成任 ...

  9. python-函数4(递归、高阶函数)

    python-函数4(递归.高阶函数) 递归 在函数内部,可以调用其他函数.如果一个函数在内部调用自身本身,这个函数就是递归函数. 递归特性: 1. 递归必须有一个明确的结束条件 2. 每次进入更深一 ...

  10. Linux20期学习笔记 Day1

    Linux就该这么学第一章 1.4重置root管理员密码  放到红帽RHCSA考前辅导视频 源代码安装: 弊端:(好处第二章讲解) 1.难度高,安装困难 2.自己解决依赖关系(暂时不说) 新技术:RP ...