# 解题思路

这题不难,但是原谅我一开始的傻逼想法,一会儿再给大家透露透露。

先说怎么做这题。

显然对于 $0$ 和 $1$ 来说,异或无非也就只有两种变化

  • 异或了奇数次,$0$ 就会变成 $1$,$1$ 就会变成 $0$。
  • 异或了偶数次,$0$ 和 $1$ 都不变。

那只需要在下传标记的时候下传修改了几次就可以。

好,下面说说我那傻逼的操作。我在下传标记的时候没有给子节点的 sum 进行异或,而是只下传了标记,并且在回溯的时候没有更新父节点的 sum 值。

然后我成功的没过样例,然鹅这并不傻逼,改过来就行了吗,对吧,但是,傻逼的来了,我改的时候没有按照上面的来改,而是在进行更新时,沿途将节点打一个flag标记,假装这一段区间需要更改。

哈哈哈哈哈,然后我成功的获得了 T 四个点的好成绩。

什么鬼,我居然忘记更新父节点,果然还是我太菜了。

我决定还是把这个代码放上吧。

# 附上代码

放上我的傻逼错误代码

#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
int n, m;
const int maxn = 2e5+;
struct node {int l, r, sum, t, tag, flag;}tree[maxn << ];
struct Tree {
#define Lson (k << 1)
#define Rson ((k << 1) | 1)
template <typename T> inline void read(T &x) {
x = ; T f = ; char c = getchar();
while (c < '' || c > '') {if(c == '-') f = -; c = getchar();}
while (c <= '' && c >= '') {x = x* + c-''; c = getchar();}
x *= f;
}
void build(int k, int ll, int rr) {
tree[k].l = ll, tree[k].r = rr;
tree[k].flag = tree[k].t = ;
if(tree[k].l == tree[k].r) {
scanf("%1d", &tree[k].sum);
return ;
}
int mid = (tree[k].l + tree[k].r) >> ;
build(Lson, tree[k].l, mid);
build(Rson, mid+, tree[k].r);
tree[k].sum = tree[Lson].sum + tree[Rson].sum;
}
void push_down(int k) {
tree[Lson].t += tree[k].tag;
tree[Rson].t += tree[k].tag;
tree[Lson].tag += tree[k].tag;
tree[Rson].tag += tree[k].tag;
tree[k].tag = ;
}
void update(int k, int L, int R) {
if(tree[k].l >= L && tree[k].r <= R) {
tree[k].t ++;
tree[k].tag ++;
return;
}
tree[k].flag = ;
if(tree[k].tag) push_down(k);
int mid = (tree[k].l + tree[k].r) >> ;
if(L <= mid) update(Lson, L, R);
if(R > mid) update(Rson, L, R);
}
int query(int k, int L, int R) {
int ans = ;
if(tree[k].l >= L && tree[k].r <= R && tree[k].flag == ) {
if(tree[k].t % == ) return (tree[k].r-tree[k].l+)-tree[k].sum;
else return tree[k].sum;
}
if(tree[k].tag) push_down(k);
int mid = (tree[k].l + tree[k].r) >> ;
if(L <= mid) ans += query(Lson, L, R);
if(R > mid) ans += query(Rson, L, R);
return ans;
}
Tree () {
read(n), read(m);
build(, , n);
int opt, l, r;
for(int i=; i<=m; i++) {
read(opt), read(l), read(r);
if(opt == ) update(, l, r);
else printf("%d\n", query(, l, r));
}
}
}T;
int main() {return ;}

好,我们再来看看正确的代码

#include <iostream>
#include <cstring>
#include <cstdio>
using namespace std;
int n, m;
const int maxn = 2e5+;
struct node {int l, r, sum, t, tag, flag;}tree[maxn << ];
struct Tree {
#define Lson (k << 1)
#define Rson ((k << 1) | 1)
template <typename T> inline void read(T &x) {
x = ; T f = ; char c = getchar();
while (c < '' || c > '') {if(c == '-') f = -; c = getchar();}
while (c <= '' && c >= '') {x = x* + c-''; c = getchar();}
x *= f;
}
void build(int k, int ll, int rr) {
tree[k].l = ll, tree[k].r = rr;
tree[k].flag = tree[k].t = ;
if(tree[k].l == tree[k].r) {
scanf("%1d", &tree[k].sum);
return ;
}
int mid = (tree[k].l + tree[k].r) >> ;
build(Lson, tree[k].l, mid);
build(Rson, mid+, tree[k].r);
tree[k].sum = tree[Lson].sum + tree[Rson].sum;
}
void push_down(int k) {
if(tree[k].tag % == )
tree[Lson].sum = (tree[Lson].r-tree[Lson].l+)-tree[Lson].sum,
tree[Rson].sum = (tree[Rson].r-tree[Rson].l+)-tree[Rson].sum;
tree[Lson].tag += tree[k].tag;
tree[Rson].tag += tree[k].tag;
tree[k].tag = ;
}
void update(int k, int L, int R) {
if(tree[k].l >= L && tree[k].r <= R) {
tree[k].tag ++;
tree[k].sum = (tree[k].r-tree[k].l+)-tree[k].sum;
return;
}
if(tree[k].tag) push_down(k);
int mid = (tree[k].l + tree[k].r) >> ;
if(L <= mid) update(Lson, L, R);
if(R > mid) update(Rson, L, R);
tree[k].sum = tree[Lson].sum + tree[Rson].sum;
}
int query(int k, int L, int R) {
int ans = ;
if(tree[k].l >= L && tree[k].r <= R)
return tree[k].sum;
if(tree[k].tag) push_down(k);
int mid = (tree[k].l + tree[k].r) >> ;
if(L <= mid) ans += query(Lson, L, R);
if(R > mid) ans += query(Rson, L, R);
return ans;
}
Tree () {
read(n), read(m);
build(, , n);
int opt, l, r;
for(int i=; i<=m; i++) {
read(opt), read(l), read(r);
if(opt == ) update(, l, r);
else printf("%d\n", query(, l, r));
}
}
}T;
int main() {return ;}

「 Luogu P2574 」 XOR的艺术——线段树的更多相关文章

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

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

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

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

  3. LOJ 2991 「THUSC 2016」补退选——trie+线段树合并或vector

    题目:https://loj.ac/problem/2291 想了线段树合并的做法.就是用线段树维护 trie 的每个点在各种时间的操作. 然后线段树合并一番,线段树维护前缀最大值,就是维护最大子段和 ...

  4. 【LOJ6620】「THUPC 2019」不等式 / inequality(线段树)

    点此看题面 大致题意: 给你两个长度为\(n\)的数组\(a_i\)和\(b_i\),定义\(f_k(x)=\sum_{i=1}^k|a_ix+b_i|\),对于\(k=1\sim n\)的每个\(f ...

  5. 【LOJ】#3109. 「TJOI2019」甲苯先生的线段树

    LOJ#3109. 「TJOI2019」甲苯先生的线段树 发现如果枚举路径两边的长度的话,如果根节点的值是$x$,左边走了$l$,右边走了$r$ 肯定答案会是$(2^{l + 1} + 2^{r + ...

  6. 【洛谷P2574】XOR的艺术

    XOR的艺术 题目链接 用线段树维护sum, 修改时 tag[p]^=1; sum=r-l+1-sum; 详见代码 #include<iostream> #include<cstdi ...

  7. 「Luogu 3792」由乃与大母神原型和偶像崇拜

    更好的阅读体验 Portal Portal1: Luogu Description 给你一个序列\(a\) 每次两个操作: 修改\(x\)位置的值为\(y\): 查询区间\([l, r]\)是否可以重 ...

  8. loj#2312. 「HAOI2017」八纵八横(线性基 线段树分治)

    题意 题目链接 Sol 线性基+线段树分治板子题.. 调起来有点自闭.. #include<bits/stdc++.h> #define fi first #define se secon ...

  9. 「POI2011 R2 Day2」Tree Rotations【线段树合并】

    题目链接 [BZOJ] [洛谷] [LOJ] 题解 由于是前序遍历,那么讨论一棵树上的逆序对的情况. 两个节点都在左子树上 两个节点都在右子树上 两个节点分别在不同的子树上. 前两种情况其实也可以归结 ...

随机推荐

  1. bzoj 3796: Mushroom追妹纸【二分+后缀数组+st表】

    把三个串加上ASCII大于z的分隔符连起来,然后求SA 显然每个相同子串都是一个后缀的前缀,所以枚举s1的每个后缀的最长和s2相同的前缀串(直接在排序后的数组里挨个找,最近的两个分别属于s1和s2的后 ...

  2. influxdb数据库的安装部署(windows)二

    1.把下载好的文件解压到目录中 2.以管理员身份运行cmd进入influxdb-1.7.6-1文件夹 3.生成influxdb数据的默认配置Config文件 4.修改Config配置信息 5.用配置好 ...

  3. 给Clouderamanager集群里安装可视化分析利器工具Hue步骤(图文详解)

    扩展博客 以下,是我在手动的CDH版本,安装Hue. CDH版本大数据集群下搭建Hue(hadoop-2.6.0-cdh5.5.4.gz + hue-3.9.0-cdh5.5.4.tar.gz)(博主 ...

  4. Hexo瞎折腾系列(3) - 添加GitHub彩带和GitHub Corner

    页面右上角添加GitHub彩带 你可以在这里找到一共12种样式的GitHub彩带,复制其中的超链代码. 在themes\next\layout\_layout.swig目录下找到头部彩带相关的代码: ...

  5. the little schemer 笔记(10)

    第十章 What Is  the Value of All of This? entry条目 是由list表组成的 pair 对,pair 对的第一个list表是集合 set.另外,两个list表的长 ...

  6. bzoj2301 [HAOI2011]Problem b【莫比乌斯反演 分块】

    传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2301 很好的一道题.首先把每个询问转化为4个子询问,最后的结果就是这四个子询问的记过加加减减 ...

  7. D. The Door Problem 带权并查集

    http://codeforces.com/contest/776/problem/D 注意到每扇门都有两个东西和它连接着,那么,如果第i扇门的状态是1,也就是已经打开了,那么连接它的两个按钮的状态应 ...

  8. PHP的扩展知识

    1. 图片的上传大小受哪一些限制? 答:浏览器 其实php.ini文件里面 1. upload_max_filesize = 2M  限制单个文件上传大小 2. post_max_size = 8M ...

  9. AJPFX的反射学习笔记

    反射是描述 数据结构的结构        属性.方法(数据)元数据        类(数据结构)描述数据的结构-->类也是特殊的对象---->元数据        CLASS类 描述数据结 ...

  10. Map集合的实现类

    Map的继承关系: Map接口的常用实现类: 1.HashMap.Hashtable(t是小写) HashMap不是线程安全的,key.value的值都可以是null. Hashtable是线程安全的 ...