[luogu3834]静态区间第k小【主席树】
传送门:https://www.luogu.org/problemnew/show/P3834
题目描述
如题,给定N个整数构成的序列,将对于指定的闭区间查询其区间内的第K小值。
分析
很多人都说是用主席树来维护,一开始蒟蒻chh做这道题的时候还以为是分块乱搞,但是发现常数非常的大,就转用主席树了。这道题我们维护的主席树是一个权值线段树,意思就是维护一个桶,那么我们手动模拟主席树的建树过程,可以发现如果我们要查询区间\([l,r]\),那么发现编号为l-1的主席树和编号为r的主席树上对应的链上的差值就是我们区间上有多少个数是这样的。参照二叉搜索树的查找第k大的方法,我们就只需要每一次比较两个链上数值的差值和我们需要k大小,选择路径查询就可以做出来了。
注一句:这道题目因为维护的是权值线段树,那么题目中给出的1e9实在是太大了,那么我们就离散化一下,还是非常简单的。
ac代码
#include <bits/stdc++.h>
#define ll long long
#define ms(a, b) memset(a, b, sizeof(a))
#define inf 0x3f3f3f3f
#define N 200005
using namespace std;
template <typename T>
inline void read(T &x) {
x = 0; T fl = 1;
char ch = 0;
while (ch < '0' || ch > '9') {
if (ch == '-') fl = -1;
ch = getchar();
}
while (ch >= '0' && ch <= '9') {
x = (x << 1) + (x << 3) + (ch ^ 48);
ch = getchar();
}
x *= fl;
}
struct Last_segment_tree {
#define mid ((l + r)>> 1)
int tot;
int rt[N];
struct node {
int lc, rc, s;
node() {
lc = rc = s = 0;
}
}tr[N * 35];
Last_segment_tree() {
tot = 0;
}
void build(int &nod, int l, int r) {
nod = ++ tot;
if (l == r) return;
build(tr[nod].lc, l, mid);
build(tr[nod].rc, mid + 1, r);
}
void update(int &nod, int pre, int l, int r, int k) {
nod = ++ tot;
tr[nod] = tr[pre]; tr[nod].s ++;
if (l == r) return;
if (k <= mid) update(tr[nod].lc, tr[pre].lc, l, mid, k);
else update(tr[nod].rc, tr[pre].rc, mid + 1, r, k);
}
int query(int x, int y, int l, int r, int k) {
if (l == r) return l;
int a = tr[tr[y].lc].s - tr[tr[x].lc].s;
if (a >= k) return query(tr[x].lc, tr[y].lc, l, mid, k);
else return query(tr[x].rc, tr[y].rc, mid + 1, r, k - a);
}
int kth(int l, int r, int ql, int qr, int k) {
return query(rt[ql - 1], rt[qr], l, r, k);
}
}lstr;
int n, m;
int a[N], disc[N];
int main() {
read(n); read(m);
for (int i = 1; i <= n; i ++) {
read(a[i]);
disc[i] = a[i];
}
sort(disc + 1, disc + 1 + n);
int d = unique(disc + 1, disc + 1 + n) - disc - 1;
lstr.build(lstr.rt[0], 1, d);
for (int i = 1; i <= n; i ++) {
a[i] = lower_bound(disc + 1, disc + 1 + d, a[i]) - disc;
lstr.update(lstr.rt[i], lstr.rt[i - 1], 1 , d, a[i]);
}
while (m --) {
int x, y, z;
read(x); read(y); read(z);
int p = lstr.kth(1, d, x, y, z);
printf("%d\n", disc[p]);
}
return 0;
}
[luogu3834]静态区间第k小【主席树】的更多相关文章
- Dynamic Rankings || 动态/静态区间第k小(主席树)
JYF大佬说,一星期要写很多篇博客才会有人看 但是我做题没有那么快啊QwQ Part1 写在前面 区间第K小问题一直是主席树经典题=w=今天的重点是动态区间第K小问题.静态问题要求查询一个区间内的第k ...
- POJ2104 K-th Number —— 静态区间第k小
题目链接:http://poj.org/problem?id=2104 K-th Number Time Limit: 20000MS Memory Limit: 65536K Total Sub ...
- 静态区间第K小(整体二分、主席树)
题目链接 题解 主席树入门题 但是这里给出整体二分解法 整体二分顾名思义是把所有操作放在一起二分 想想,如果求\([1-n]\)的第\(k\)小怎么二分求得? 我们可以二分答案\(k\), \(O(n ...
- 主席树(可持久化线段树)静态区间第K小
传送门主席树 #include <bits/stdc++.h> #define int long long using namespace std; const int maxn=2e5+ ...
- POJ2104&&HDU2665(静态区间第K小)
题目大意 给定一个有N个数字的序列,然后又m个查询,形式如下: l r k 要求你返回区间[l,r]第k小的数是哪个 题解 终于弄懂主席树是个啥东西了,O(∩_∩)O~~,这题正是主席树的裸题,主席树 ...
- 洛谷.3834.[模板]可持久化线段树(主席树 静态区间第k小)
题目链接 //离散化后范围1~cnt不要错 #include<cstdio> #include<cctype> #include<algorithm> //#def ...
- HDU2665 求区间第K大 主席树
题目链接 http://acm.hdu.edu.cn/showproblem.php?pid=2665 代码: //#include<bits/stdc++.h> #include< ...
- 静态区间第k小 - 整体二分
蒟蒻终于学会整体二分啦! 思路 实现 丑陋无比的代码 #include <bits/stdc++.h> using namespace std; const int N = 200005; ...
- POJ-2104-K-th Number(区间第K大+主席树模板题)
Description You are working for Macrohard company in data structures department. After failing your ...
随机推荐
- [转]curl的错误代码
转贴者按: 今天在使用curl的时候碰到了一个错误,如下所示: External Program Failed: D:\Tools\curl\curl.exe (return code was 18) ...
- MiniProfiler工具介绍(监控EF生成的SQL语句)--EF,迷你监控器,哈哈哈
十年河东,十年河西,莫欺少年穷... 今天是抄袭的别人的博客,不过我感觉蛮好,挺有用,特别是老板让你优化EF项目SQL耗时的情况下,你可以采用这种方式来优化你的LINQ. 时间很宝贵,废话还是不多说, ...
- Luogu P1896 [SCOI2005]互不侵犯
一道超级简单的状压DP题所以说状压是个好东西 看数据范围,同时我们发现一个格子要么放国王or不放,因此可以用二进制数来表示某一行的国王放置信息 于是我们马上想到用\(f_{i,j}\)表示放了前\(i ...
- [HAOI2017]供给侧改革[离线、trie]
题意 题目链接 分析 由于数据随机所以 LCP 不会很长,维护每个位置后 40 个字符构成的01串. 将询问离线维护,以当前右端点为 R 的每个长度的 LCP 的第一个出现位置 f(这个信息显然是单调 ...
- 小白学Docker之基础篇
系列文章: 小白学Docker之基础篇 小白学Docker之Compose 小白学Docker之Swarm PS: 以下是个人作为新手小白学习docker的笔记总结 1. docker是什么 百科上的 ...
- Libp2p学习(一)
Libp2p学习 参考资料:libp2p-specifications : https://github.com/libp2p/specs 持续更新ing 1. 介绍 Libp2p的实现目标是: 支持 ...
- 针对负载均衡集群中的session解决方案的总结
在日常运维工作中,当给Web站点使用负载均衡之后,必须面临的一个重要问题就是Session的处理办法,无论是PHP.Python.Ruby还是Java语言环境,只要使用服务器保存Session,在做负 ...
- B. Vasya and Isolated Vertices
链接 [http://codeforces.com/contest/1065/problem/B] 题意 给你n个点,m条边,让你找最多孤立点和最少孤立点,不能有自环路 分析 对于最少max(0,n- ...
- vs2015安装及初步试用
Vs2015一直都听说好用,便捷.之前用vc++6.0,总感觉界面很灰,让人编程兴趣不高,恰巧借此机会,安装一下vs2015,从编译器上体验下编程的舒心,方便.希望我不会变得太懒... 首先,我下的是 ...
- Linux内核第三节 20135332武西垚
总结部分: Linux内核源代码: Arch 支持不同cpu的源代码:主要关注x86 Init 内核启动的相关代码:主要关注main.c,整个Linux内核启动代码start_kernel函数 K ...