数据结构——线段树
来源:互联网 发布:java形参 编辑:程序博客网 时间:2024/06/05 05:57
方便简写的头文件
#define lchild rt << 1, l, m#define rchild rt << 1 | 1, m + 1, r
节点数据向上更新
1.区间求和:
void push_up(int rt) { tree[rt] = tree[rt << 1] + tree[rt << 1 | 1];}
2.区间取最大值:
void push_up(int rt) { tree[rt] = max(tree[rt << 1], tree[rt << 1 | 1]);}
节点懒惰标记下推:
1.区间求和:
void push_down(int rt, int len) { tree[rt << 1] += lazy[rt] * (len - (len >> 1)); lazy[rt << 1] += lazy[rt]; tree[rt << 1 | 1] += lazy[rt] * (len >> 1); lazy[rt << 1 | 1] += lazy[rt]; lazy[rt] = 0;}
2.区间取最大值:
void push_down(int rt) { tree[rt << 1] += lazy[rt]; lazy[rt << 1] += lazy[rt]; tree[rt << 1 | 1] += lazy[rt]; lazy[rt << 1 | 1] += lazy[rt]; lazy[rt] = 0;}
建树:
void build(int rt = 1, int l = 1, int r = N) { if (l == r) { std::cin >> tree[rt]; return; } int m = (l + r) >> 1; build(lchild); build(rchild); push_up(rt);}
单个节点更新:
void update(int p, int delta, int rt = 1, int l = 1, int r = N) { if (l == r) { tree[rt] += delta; return; } int m = (l + r) >> 1; if (p <= m) update(p, delta, lchild); else update(p, delta, rchild); push_up(rt);}
区间更新:
void update(int L, int R, int delta, int rt = 1, int l = 1, int r = N) { if (L <= l && r <= R) { tree[rt] += delta * (r - l + 1); lazy[rt] += delta; return; } if (lazy[rt]) push_down(rt, r - l + 1); int m = (l + r) >> 1; if (L <= m) update(L, R, delta, lchild); if (R > m) update(L, R, delta, rchild); push_up(rt);}
区间查询:
int query(int L, int R, int rt = 1, int l = 1, int r = N) { if (L <= l && r <= R) return tree[rt]; if (lazy[rt]) push_down(rt, r - l + 1); int m = (l + r) >> 1, ret = 0; if (L <= m) ret += query(L, R, lchild); if (R > m) ret += query(L, R, rchild); return ret;}
最后提醒一下,线段树的使用的空间是一般空间的4倍左右。(如果题目中的数据没有很严格要求的话,一般2倍也是行的)
0 0
- 数据结构——线段树
- 数据结构——线段树
- 数据结构——线段树
- 数据结构专题——线段树线段树
- 数据结构专题——线段树
- 数据结构专题——线段树
- 数据结构专题——线段树
- 数据结构学习——线段树
- 数据结构专题——线段树
- 数据结构专题——线段树
- 数据结构专题——线段树
- 数据结构——线段树的基础知识
- 数据结构专题——线段树
- 数据结构专题——线段树
- 数据结构专题——线段树
- 数据结构专题——线段树
- 数据结构专题——线段树
- ACM常用模板——数据结构——线段树
- Median of Two Sorted Arrays
- 汇编语言学习之“段地址*16+偏移地址=物理地址”的本质
- Max retries exceeded with url Error
- LeetCode 404. Sum of Left Leaves 题解
- Alexnet输入大小调整的经验
- 数据结构——线段树
- 152. Maximum Product Subarray Medium
- poj2182 Lost Cows(经典单点更新)
- C++第2次实验:简单计算问题体验
- solr入门--solrJ搜索引擎入门
- web前端学习之路(1)Javascript DOM编程艺术总结
- Android添加横线和竖线分割界面
- C语言函数嵌套定义问题
- 创建守护进程为什么fork两次