尧图网站建设 尧图网络
  • 首页
  • 关于我们
  • 服务项目
  • 案例展示
  • 建站流程
  • 资讯中心
  • 联系我们
首页/资讯中心/详情

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

小波矩阵树:高效静态区间第 K 大查询
📅 发布时间:2026/6/20 3:50:42

小波矩阵树:高效静态区间第 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);}
};

相关新闻

  • 分数运算类
  • 坐标压缩与离散化
  • 撸一个功能强大的基于语义的图像检索系统

最新新闻

  • S12S BDM硬件握手协议:ACK脉冲原理与嵌入式调试实战
  • 前向车辆最小转弯约束下的两点间最短路径生成工具(MATLAB实现+图形可视化)
  • 2026年即时零售无人仓加盟推荐:无人外卖仓/外卖闪电仓/前置仓无人仓/即时零售运营加盟全解析 - 海棠依旧大
  • 2026年东莞全域保洁服务公司推荐:开荒清洁/外墙清洗/石材养护/甲醛治理/油烟管道清洁/日常驻场保洁 - 海棠依旧大
  • CVE-2025-55182本地复现:路径遍历漏洞原理与实战利用详解
  • 麻省理工研究人员打造 Fractal 操作系统,获苹果 M1 芯片新发现

日新闻

  • 信任的进化:技术实现详解——如何用JavaScript构建博弈论模拟器
  • Terrakube自定义工作流:如何集成OPA、Infracost等工具扩展IaC能力
  • grunt-concurrent快速入门:5分钟学会并行运行Grunt任务

周新闻

  • 3步解锁iOS设备:applera1n激活锁绕过完全指南
  • 39 2026 人工智能证书终极盘点,普通人选 AI 证书可以从这些方向入手
  • Redis 暴露公网有多危险?从端口检查到补救步骤

月新闻

  • 【总结】入门篇:50句话让你记住架构核心概念
  • WeChatMsg技术方案解析:实现Mac微信数据自主管理的完整解决方案
  • WeChatMsg:革新性微信数据备份方案,打造你的专属数字记忆库

关于尧图

  • 公司简介
  • 团队介绍
  • 企业文化
  • 荣誉资质

服务项目

  • 定制开发
  • 电商建站
  • UI 设计
  • 运维服务

快速链接

  • 案例展示
  • 建站流程
  • 常见问题
  • 资讯中心

联系方式

  • 📍北京市朝阳区互联网产业园 A 座 10 层
  • 📞400-888-8888
  • ✉️contact@rkmt.cn
  • 🕐周一至周日 9:00-21:00

© 2024 北京尧图网络科技有限公司 版权所有 | 京 ICP 备 XXXXXXXX 号