树状数组模板
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<typename T> struct BIT { int n; vector<T> w; BIT() {} BIT(int n) { this->n = n; w.resize(n + 1); } void update(int x, int k) { for (; x <= n; x += x & -x) { w[x] += k; } } void update(int x, int y, int k) {//区间修改存入差分,单点查询前缀和 update(x, k), update(y, -k); } T ask(int x) { T ans = 0; for (; x; x -= x & -x) { ans += w[x]; } return ans; } T ask(int x, int y) { return ask(y) - ask(x - 1); } T kth(int k) { //查找第k小的值 T ans = 0; for (int i = __lg(n); i >= 0; i--) { int val = ans + (1 << i); if (val < n && w[val] < k) { k -= w[val]; ans = val; } } return ans + 1; } T get(auto x) { //获取逆序对数量 this->n = x.size() - 1; w.resize(n + 1); vector<pair<int, int>> a; for (int i = 1; i <= n; i++) { a.emplace_back(x[i], i); } sort(a.begin(), a.end()); T ans = 0; for (auto [val, idx] : a) { ans += ask(idx + 1, n); update(idx, 1); } return ans; } };
本文作者:Ke_scholar
本文链接:https://www.cnblogs.com/Kescholar/p/17927354.html
版权声明:本作品采用知识共享署名-非商业性使用-禁止演绎 2.5 中国大陆许可协议进行许可。
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】凌霞软件回馈社区,博客园 & 1Panel & Halo 联合会员上线
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】博客园社区专享云产品让利特惠,阿里云新客6.5折上折
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步