线段树模板重制
1.并查集模板2.求质因数模板3.二分图最大匹配模板(匈牙利算法)4.欧拉函数模板5.ST表模板6.快速幂模板7.字典树模板8.矩阵模板9.Dijkstra单源最短路模板10.最近公共祖先模板(LCA)11.拓扑排序模板12.区间素数筛模板13.Kruskal和Prim模板14.树状数组模板15.二维坐标离散化模板16.单点修改区间查最值-树状数组模板17.KMP模板18.二叉搜索树模板19.DIjkstra进阶模板 路径记录 按权重(结点数最小等)记录20.判断负环模板21.Exgcd 模板22.压位高精度模板23.线段树模板24.扫描线模板25.莫队模板26.带修莫队模板27.SCC缩点模板28.取模+组合数29.FFT 高精度乘法模板30.字符串自然溢出哈希/单哈希/双哈希模板31.树模板32.dsu on tree 模板
33.线段树模板重制
34.主席树模板35.大数质因数分解模板36.线段树合并模板37.int128输入输出流38.Meissel_Lehmer模板39.浮点高精度40.自适应辛普森法41.unordered_map随机底数种子template<class Node> struct SegmentTree { #define lc u<<1 #define rc u<<1|1 const int n, N; vector<Node> tr; SegmentTree(): n(0) {} SegmentTree(int n_): n(n_), N(n * 4 + 10) { tr.reserve(N); tr.resize(N); } SegmentTree(vector<int> init) : SegmentTree(init.size()) { function<void(int, int, int)> build = [&](int u, int l, int r) { tr[u].l = l, tr[u].r = r; init_lazy(tr[u]); if (l == r) { tr[u] = {l, r, 0, init[l], init[l], 1, 1}; return ; } i64 mid = (l + r) >> 1; build(lc, l, mid); build(rc, mid + 1, r); pushup(tr[u], tr[lc], tr[rc]); }; build(1, 1, n); } void cal_lazy(Node & fa, Node & ch) { i64 b = fa.add; ch.Max += b; ch.Min += b; } void tag_union(Node& fa, Node& ch) { i64 b = fa.add; ch.add += b; } void init_lazy(Node& u) { u.add = 0; } void pushdown(i64 u) { if (tr[u].add != 0) { cal_lazy(tr[u], tr[lc]); cal_lazy(tr[u], tr[rc]); tag_union(tr[u], tr[lc]); tag_union(tr[u], tr[rc]); init_lazy(tr[u]); } } void pushup(Node& U, Node& L, Node& R) { //上传 U.Max = max(L.Max, R.Max); U.Min = min(L.Min, R.Min); if (L.Max < R.Min && L.up && R.up) { U.up = 1; } else { U.up = 0; } if (L.Min > R.Max && L.down && R.down) { U.down = 1; } else { U.down = 0; } } void modify(int u, int l, int r, int k) { if (tr[u].l >= l && tr[u].r <= r) { tr[u].add += k; tr[u].Max += k; tr[u].Min += k; return ; } pushdown(u); int mid = (tr[u].l + tr[u].r) >> 1; if (l <= mid) modify(lc, l, r, k); if (r > mid) modify(rc, l, r, k); pushup(tr[u], tr[lc], tr[rc]); } Node query(int u, int l, int r) { //区查 if (l <= tr[u].l && tr[u].r <= r) return tr[u]; i64 mid = tr[u].l + tr[u].r >> 1; pushdown(u); i64 res = LLONG_MIN >> 1; if (r <= mid) return query(lc, l, r); if (l > mid) return query(rc, l, r); Node U; Node L = query(lc, l, r), R = query(rc, l, r); pushup(U, L, R); return U; } }; struct Node { //线段树定义 i64 l, r, add; i64 Max, Min; bool up, down; };
本文作者:Ke_scholar
本文链接:https://www.cnblogs.com/Kescholar/p/18339951
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
2023-08-03 23 暑假友谊赛 No.3
2023-08-03 SMU Summer 2023 Contest Round 9(2019 山东省大学生程序设计竞赛)
2023-08-03 SMU Summer 2023 Contest Round 8(2019 陕西省大学生程序设计竞赛)