归并树 学习笔记

归并树

Problem

给定一个长为 n n n 的数组。
q q q 次查询,每次查询包括一个区间,需要回答关于区间元素排序的问题

示例 :区间第 k k k 大值,link

数据强制在线 , n , q ≤ 1 0 5 n,q \leq 10^5 n,q≤105。

Algorithm description

Method

归并树顾名思义,就是逐个归并的树。

每个节点是其子节点代表的数组归并后的数组,这样能使任意一个节点有序。

也就是说,建树时,每个节点代表了 a l a_l al 至 a r a_r ar 归并后的数组

我们在实现时,为了节约空间,可以开 dep × n \text{dep}\times n dep×n 的归并数组,每一层为下一层归并的结果。

这种树的优势在于,能够像线段树一样 O ( log ⁡ n ) O(\log n) O(logn) 统计出可以叠加的排序的结果

Code

以 POJ2104 (见上文)为例,可以二分答案再查找。

cpp 复制代码
int sorted[25][2000001], a[200001];

void build(int l, int r, int dep){
    if(l == r){
        sorted[dep][l] = a[l]; return;
    }
    int mid = l + r >> 1;
    build(l, mid, dep + 1);
    build(mid + 1, r, dep + 1);
    // Merging.
    int pos = l, pos1 = mid + 1, tot = l;
    while(pos <= mid && pos1 <= r){
        if(sorted[dep + 1][pos] < sorted[dep + 1][pos1])
            sorted[dep][tot] = sorted[dep + 1][pos], pos++, tot++;
        else
            sorted[dep][tot] = sorted[dep + 1][pos1], pos1++, tot++;
    }
    while(pos <= mid) sorted[dep][tot] = sorted[dep + 1][pos], pos++, tot++;
    while(pos1 <= r) sorted[dep][tot] = sorted[dep + 1][pos1], pos1++, tot++;
}
int query(int l, int r, int x, int y, int tar, int dep){
    if(x <= l && r <= y){
    	// Here it is possible to calculate the sum thanks to the merging above.
        return upper_bound(sorted[dep] + l, sorted[dep] + r + 1, tar) - sorted[dep] - l;
    }
    int mid = l + r >> 1, ans = 0;
    if(x <= mid) ans += query(l, mid, x, y, tar, dep + 1);
    if(mid < y) ans += query(mid + 1, r, x, y, tar, dep + 1);
    return ans;
}
相关推荐
古希腊掌管学习的神1 小时前
[搜广推]王树森推荐系统笔记——曝光过滤 & Bloom Filter
算法·推荐算法
qystca1 小时前
洛谷 P1706 全排列问题 C语言
算法
浊酒南街1 小时前
决策树(理论知识1)
算法·决策树·机器学习
就爱学编程1 小时前
重生之我在异世界学编程之C语言小项目:通讯录
c语言·开发语言·数据结构·算法
学术头条1 小时前
清华、智谱团队:探索 RLHF 的 scaling laws
人工智能·深度学习·算法·机器学习·语言模型·计算语言学
Schwertlilien2 小时前
图像处理-Ch4-频率域处理
算法
IT猿手2 小时前
最新高性能多目标优化算法:多目标麋鹿优化算法(MOEHO)求解TP1-TP10及工程应用---盘式制动器设计,提供完整MATLAB代码
开发语言·深度学习·算法·机器学习·matlab·多目标算法
__lost2 小时前
MATLAB直接推导函数的导函数和积分形式(具体方法和用例)
数学·算法·matlab·微积分·高等数学
thesky1234562 小时前
活着就好20241224
学习·算法
ALISHENGYA2 小时前
全国青少年信息学奥林匹克竞赛(信奥赛)备考实战之分支结构(实战项目二)
数据结构·c++·算法