当前位置: 首页 > news >正文

小波矩阵树:高效静态区间第 K 大查询

小波矩阵树:高效静态区间第 K 大查询

手写 bitset 压位,以 \(\mathcal O(N \log N)\) 的时间复杂度和 \(\mathcal O(N + \frac{N \log N}{64})\) 的空间建树后,实现单次 \(\mathcal O(\log N)\) 复杂度的区间第 \(k\) 大值询问。建议使用 \(\texttt{0-idx}\) 计数法,但是经测试 \(\texttt{1-idx}\) 也有效,但需要更多的检验。

#define __count(x) __builtin_popcountll(x)
struct Wavelet {vector<int> val, sum;vector<u64> bit;int t, n;int getSum(int i) {return sum[i >> 6] + __count(bit[i >> 6] & ((1ULL << (i & 63)) - 1));}Wavelet(vector<int> v) : val(v), n(v.size()) {sort(val.begin(), val.end());val.erase(unique(val.begin(), val.end()), val.end());int n_ = val.size();t = __lg(2 * n_ - 1);bit.resize((t * n + 64) >> 6);sum.resize(bit.size());vector<int> cnt(n_ + 1);for (int &x : v) {x = lower_bound(val.begin(), val.end(), x) - val.begin();cnt[x + 1]++;}for (int i = 1; i < n_; ++i) {cnt[i] += cnt[i - 1];}for (int j = 0; j < t; ++j) {for (int i : v) {int tmp = i >> (t - 1 - j);int pos = (tmp >> 1) << (t - j);auto setBit = [&](int i, u64 v) {bit[i >> 6] |= (v << (i & 63));};setBit(j * n + cnt[pos], tmp & 1);cnt[pos]++;}for (int i : v) {cnt[(i >> (t - j)) << (t - j)]--;}}for (int i = 1; i < sum.size(); ++i) {sum[i] = sum[i - 1] + __count(bit[i - 1]);}}int small(int l, int r, int k) {r++;for (int j = 0, x = 0, y = n, res = 0;; ++j) {if (j == t) return val[res];int A = getSum(n * j + x), B = getSum(n * j + l);int C = getSum(n * j + r), D = getSum(n * j + y);int ab_zeros = r - l - C + B;if (ab_zeros > k) {res = res << 1;y -= D - A;l -= B - A;r -= C - A;} else {res = (res << 1) | 1;k -= ab_zeros;x += y - x - D + A;l += y - l - D + B;r += y - r - D + C;}}}int large(int l, int r, int k) {return small(l, r, r - l - k);}
};
http://www.rkmt.cn/news/29235.html

相关文章:

  • 分数运算类
  • 坐标压缩与离散化
  • 撸一个功能强大的基于语义的图像检索系统
  • 数论常见结论及例题
  • N8N Workflow Collection - 专业级自动化工作流库 - 详解
  • 莫比乌斯函数/反演
  • 同余方程组、拓展中国剩余定理 excrt
  • Apache POI 在 Linux 无图形界面环境下因字体配置问题导致Excel导出失败的解决方案 - 详解
  • 扩展欧几里得 exgcd
  • 防爆模乘
  • 20232314 2025-2026-1 《网络与系统攻防技术》实验三实验报告
  • 最小割树 Gomory-Hu Tree
  • 图论常见结论及例题
  • 最短路径树(SPT问题)
  • 多源汇最短路(APSP问题)
  • 单源最短路径(SSSP问题)
  • 最近公共祖先 LCA
  • 题解:P3343 [ZJOI2015] 地震后的幻想乡
  • 暂存:P14214 [COI 2010] 圆圈 / KOLO
  • QMPlayer2解析
  • 2025年10月广州单位办公室搬家公司全景解析报告,基于专业测评的技术、性能及市场优势深度分析
  • 权威调研榜单:东莞工厂装修公司OP3榜单好评深度解析
  • 2025年口碑好的FPC离型纸,环氧胶离型纸推荐TOP生产厂家
  • 2025年口碑好的数字地磅,电子汽车衡地磅厂家推荐及选择建议
  • 2025年10月进口艺术漆厂家全景解析报告,基于专业测评的技术、性能及市场优势深度分析
  • 最大公约数 gcd
  • 2025年上海注册公司/上海代理记账公司最新推荐榜,聚焦企业服务品质与特色业务竞争力深度剖析
  • 2025 年国内无缝钢管厂家最新推荐榜:20#/Q355 系列 / 合金管优质品牌权威测评及选购指南
  • 2025年优秀的冷却塔,鼓风式冷却塔定制定做
  • 2025年比较好的车铣复合机床,动力刀塔车铣复合品牌厂家排行榜