线段树

什么时候用线段树

1.统计量可合并

2.修改量可合并

3.通过统计量可直接修改统计量

一句话:满足区间加法即可使用线段树维护信息

理解Lazy Tage

蓝色是要把信息及时维护的节点,红色是本次区间修改操作Lazy Tage下传停止的位置。

模板  Just a Hook  HDU-1698

#include<iostream>
#include<cstdio>
#include<algorithm>
#include<vector>
#include<queue>
using namespace std; const int maxn = * ; //线段树范围开4倍 struct Tree {
int l, r, sum, maxx;
}; Tree node[maxn];
int a[maxn];
int lazy[maxn]; void Pushdown(int rt, int m) {
if (lazy[rt]) {
lazy[rt << ] = lazy[rt];
lazy[rt << | ] = lazy[rt];
node[rt << ].sum = lazy[rt] * (m - (m >> ));
node[rt << | ].sum = lazy[rt] * (m >> );
lazy[rt] = ;
}
} void Pushup(int i) {
node[i].sum = node[i << ].sum + node[i << | ].sum;
node[i].maxx = max(node[i << ].maxx, node[i << | ].maxx);
} void Build(int i, int l, int r) {
lazy[i] = ;
node[i].l = l;
node[i].r = r;
if (l == r) {
node[i].maxx = a[l];
node[i].sum = a[l];
return;
}
int mid = l + r >> ;
Build(i << , l, mid);
Build(i << | , mid + , r);
Pushup(i);
} int getsum(int i, int l, int r) {
if (node[i].l == l && node[i].r == r) return node[i].sum;
int mid = node[i].l + node[i].r >> ;
Pushdown(i, node[i].r - node[i].l + );
if (r <= mid) return getsum(i << , l, r);
else if (l > mid) return getsum(i << | , l, r);
else return getsum(i << , l, mid) + getsum(i << | , mid + , r);
} void update(int i, int l, int r,int v) {
if (node[i].r == r && node[i].l == l) {
lazy[i] = v;
node[i].sum = v * (r - l + );
return;
}
if(node[i].l == node[i].r) return;
int mid = node[i].l + node[i].r >> ;
Pushdown(i, node[i].r - node[i].l + );
if (r <= mid) update(i << , l, r, v);
else if (l > mid) update(i << | , l, r, v);
else {
update(i << , l, mid, v);
update(i << | , mid + , r, v);
}
Pushup(i);
} int main() {
int kase = ;
int m, n, x, y, z, q;
string op;
int T;
scanf("%d", &T);
while (T--) {
scanf("%d%d", &n, &q);
for (int i = ; i <= n; i++) a[i] = ;
Build(, , n);
while (q--) {
scanf("%d%d%d", &x, &y, &z);
update(, x, y, z);
}
printf("Case %d:The total value of the hook is %d.\n", kase, getsum(, , n));
kase++;
}
return ;
}

“树状数组支持的操作:1、区间和、区间异或和、区间乘积和RMQRMQ(显然,支持的操作都具有交换律,这也算是树状数组的一大特性吧)2、单点修改 ”

code

#include<iostream>
#include<cstdio>
#include<string>
#include<algorithm>
#include<queue>
#include<set>
#include<map>
#include<cmath>
const double PI = acos(-1.0);
#define INF 0x3f3f3f3f
typedef long long ll;
using namespace std; int n, m, tree[]; inline int lowbit(int k) { //lowbit(x)是x的二进制表达式中最低位的1所对应的值
return k & -k;
} void add(int x, int k) {
while (x <= n) {
tree[x] += k;
x += lowbit(x);
}
} int sum(int x) {
int ans = ;
while (x) {
ans += tree[x];
x -= lowbit(x);
}
return ans;
} int main() {
scanf("%d%d", &n, &m);
for (int i = ; i <= n; i++) {
int a;
scanf("%d", &a);
add(i, a);
}
for (int i = ; i <= m; i++) {
int a, b, c;
scanf("%d%d%d", &a, &b, &c);
if (a == ) add(b, c);
if (a == ) printf("%d", sum(c) - sum(b - ));
}
return ;
}

HZNU-ACM寒假集训Day5小结 线段树 树状数组的更多相关文章

  1. AHUACM寒假集训II(线段树)

    B.Mayor's posters POJ2528 题目大意: D.Count Color POJ2777 题目大意:长为 L ( L ≤ 1 0 5 ) L( L\leq10^5) L(L≤105) ...

  2. 中南大学2019年ACM寒假集训前期训练题集(基础题)

    先写一部分,持续到更新完. A: 寒衣调 Description 男从戎,女守家.一夜,狼烟四起,男战死沙场.从此一道黄泉,两地离别.最后,女终于在等待中老去逝去.逝去的最后是换尽一生等到的相逢和团圆 ...

  3. HZNU-ACM寒假集训Day10小结 树-树形DP

    树形DP 加分二叉树 洛谷P1040 注意中序遍历的特点:当根节点编号k时,编号小于k的都在其左子树上,编号大于k的都在右子树 转移方程 f[i,j]=max{f[i,k-1]*f[k+1,j]+d[ ...

  4. HZNU-ACM寒假集训Day3小结 搜索

    简单搜索 1.DFS UVA 548 树 1.可以用数组方式实现二叉树,在申请结点时仍用“动态化静态”的思想,写newnode函数 2.给定二叉树的中序遍历和后序遍历,可以构造出这棵二叉树,方法是根据 ...

  5. 中南大学2019年ACM寒假集训前期训练题集(入门题)

    A: 漫无止境的八月 Description 又双叒叕开始漫无止境的八月了,阿虚突然问起长门在这些循环中团长哪几次扎起了马尾,他有多少次抓住了蝉等等问题,长门一共回复n个自然数,每个数均不超过1500 ...

  6. HZNU-ACM寒假集训Day11小结 贪心

    1.刘汝佳紫书区间问题三大情况 1.选择不相交区间 贪心策略:一定要选择第一个区间 2.区间选点问题 贪心策略:取最后一个点 3.区间覆盖问题: n个闭区间,选择尽量少的区间覆盖一条指定线段[s,t] ...

  7. HZNU-ACM寒假集训Day9小结 倍增

    LCA 倍增法求最近公共祖先 首先对于每个结点先进行dfs预处理它的深度,再记录下它们往父亲方向走2的0次,1次...k次步所到达的结点.在这里2的k次大于整棵树的最大深度. 预处理完后,需要查询两个 ...

  8. HZNU-ACM寒假集训Day8小结 最小生成树

    最小生成树(无向图) Kruskal 给所有边按从小到大排序 形成环则不选择(利用并查集) P1546 最短网络   https://www.luogu.com.cn/problem/P1546 #i ...

  9. HZNU-ACM寒假集训Day2小结 二分答案

    Day2 ---二分 这里直接给出模板 两种对应不同的情况 可以借助数轴理解 int bsearch_1(int l, int r) { while (l < r) { ; if (check( ...

随机推荐

  1. 吴裕雄 Bootstrap 前端框架开发——Bootstrap 辅助类:关闭图标

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <title> ...

  2. MQTT 协议学习:001-搭建MQTT通信环境,并抓包测试

    背景 目的:了解MQTT 通信的有关概念与流程:方便推算某些数据与文档描述是否一致. 为了能够在保证学习质量的前提下,降低配置环境的门槛,我们将服务器搭建在windwos中,实行内网间的MQTT协议访 ...

  3. zabbix java gateway配置实战案例

    zabbix java gateway配置实战案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 一.部署tomcat服务 博主推荐阅读: CentOS: https://www. ...

  4. 编程练习:实现树的层次遍历 (CVTE笔试)

    直接层次遍历是比较简单的,但是题目要求的分层打印,这就变得稍微有些麻烦 我是采用两个队列的方法实现. 1.将树结构入队列1. 2.当队列1和队列2都不为空的时候,则一直循环. 3.当队列1不为空的时候 ...

  5. spring#事件发布订阅

    1. 如果在应用中发生了某些事件,事件会被拦截和处理就好了,这样就有了很大的灵活性,至少代码不会紧密的耦合在一起, 代码的解耦就是业务的解耦,业务A的代码不用手动的调用业务B的代码,业务B只需要监听相 ...

  6. SQLserver 存储过程生成任意进制/顺序流水号

    ALTER    PROCEDURE [dbo].[TentoSerial] @num int, @ret nvarchar(10) output AS declare @StringXL nvarc ...

  7. Java 类的属性

    章节 Java 基础 Java 简介 Java 环境搭建 Java 基本语法 Java 注释 Java 变量 Java 数据类型 Java 字符串 Java 类型转换 Java 运算符 Java 字符 ...

  8. DragonFlyBSD 5.6 RC1 发布

    导读DragonFlyBSD操作系统下一个主要版本的第一个候选版本RC1现在可以进行测试.DragonFlyBSD 5.6将成为一个功能更新的版本,该功能更新将于周二晚上发布,是第一个候选版本,同时将 ...

  9. Day4-T1

    原题目 Hades 与 Dionysus 在狂饮后玩起了多米诺骨牌的小游戏. 现在桌上有 N 块多米诺骨牌,每块多米诺骨牌上半部分和下半部分上都有一个整数.每次翻转可让 一块多米诺骨牌上下翻转,即上下 ...

  10. TensorFlow2 Part2:基础知识回顾

    python面向对象编程回顾 基础概念: 面向对象的编程简称OOP,它把对象作为程序的基本单元,一个对象包含了数据和操作数据的函数. 面向对象的设计思想是抽象出Class,根据Class(类)创建In ...