【BZOJ3551】【BZOJ3545】 【ONTAK2010】 Peaks (kruskal重构树+主席树)
Description
在\(Bytemountains\)有\(~n~\)座山峰,每座山峰有他的高度\(~h_i~\)。 有些山峰之间有双向道路相连,共\(~m~\)条路径,每条路径有一个困难值,这个值越大表示越难走,现在有\(~q~\)组询问,每组询问询问从点\(~v~\)开始只经过困难值小于等于\(~x~\)的路径所能到达的山峰中第\(~k~\)高的山峰,如果无解输出\(-1\)。强制在线。
Solution
把边从小到大排序插入\(kruskal\)重构树中,对于每次询问, 倍增求出\(~v~\)祖先中第一个小于\(~x~\)的瓶颈,子树第\(~k~\)大用主席树维护即可,只不过主席树记的是第\(~k~\)小的值,记得要反过来查询。
Code
#include<bits/stdc++.h>
#define For(i, j, k) for(int i = j; i <= k; ++i)
#define Forr(i, j, k) for(int i = j; i >= k; --i)
#define Travel(i, u) for(int i = beg[u], v = to[i]; i; i = nex[i], v = to[i])
using namespace std;
inline int read() {
int x = 0, p = 1; char c = getchar();
for(; !isdigit(c); c = getchar()) if(c == '-') p = -1;
for(; isdigit(c); c = getchar()) x = (x << 1) + (x << 3) + (c ^ 48);
return x *= p;
}
inline void File() {
#ifndef ONLINE_JUDGE
freopen("bzoj3545.in", "r", stdin);
freopen("bzoj3545.out", "w", stdout);
#endif
}
const int N = 2e5 + 10, M = N << 2, MAXE = 5e5 + 10;
int n, m, q, st[N], ed[N], h[N], F[20][N], cnt, clk, ls[N], lstans;
int e = 1, beg[N], nex[M], to[M], fa[N], pos[N], rt[N], tot, hh[N], id[N];
struct edge { int u, v, w; } E[MAXE];
inline void add(int x, int y) { to[++ e] = y, nex[e] = beg[x], beg[x] = e; }
inline bool cmp(const edge &a, const edge &b) { return a.w < b.w; }
inline int find(int x) { return x == fa[x] ? x : fa[x] = find(fa[x]); }
inline void dfs(int u, int f) { pos[st[u] = ++ clk] = u; Travel(i, u) dfs(v, u); ed[u] = clk; }
inline void rebuild() {
For(i, 1, n << 1) fa[i] = id[i] = i;
For(i, 1, m) E[i].u = read(), E[i].v = read(), E[i].w = read();
sort(E + 1, E + 1 + m, cmp);
For(i, 1, m) {
int u = E[i].u, v = E[i].v;
if (find(u) == find(v)) continue;
u = fa[u], v = fa[v], hh[++ cnt] = E[i].w;
add(cnt, u), add(cnt, v); fa[u] = fa[v] = cnt;
F[0][u] = F[0][v] = cnt;
}
F[0][cnt] = cnt; dfs(cnt, cnt);
}
namespace Segment_Tree {
#define mid (l + r >> 1)
int c = 0; struct node { int lc, rc, v; } tr[N * 30];
inline void update(int &now, int pre, int l, int r, int rk) {
now = ++ c, tr[now] = tr[pre], ++ tr[now].v;
if (l < r) {
if (rk <= mid)
update(tr[now].lc, tr[pre].lc, l, mid, rk);
else
update(tr[now].rc, tr[pre].rc, mid + 1, r, rk);
}
}
inline int query(int u, int v, int l, int r, int rk) {
if (l == r) return l;
int num = tr[tr[v].lc].v - tr[tr[u].lc].v;
if (rk <= num)
return query(tr[u].lc, tr[v].lc, l, mid, rk);
else
return query(tr[u].rc, tr[v].rc, mid + 1, r, rk - num);
}
#undef mid
}
using namespace Segment_Tree;
inline void LS() {
sort(ls + 1, ls + 1 + n);
tot = unique(ls + 1, ls + 1 + n) - ls - 1;
For(i, 1, n) h[i] = lower_bound(ls + 1, ls + 1 + tot, h[i]) - ls;
For(i, 1, cnt) {
if (pos[i] <= n)
update(rt[i], rt[i - 1], 1, tot, h[pos[i]]);
else
rt[i] = rt[i - 1];
}
For(j, 1, 18) For(i, 1, cnt) F[j][i] = F[j - 1][F[j - 1][i]];
}
int main() {
File();
cnt = n = read(), m = read(), q = read();
For(i, 1, n) ls[i] = h[i] = read();
rebuild(), LS();
while (q --) {
int v = read(), x = read(), k = read();
if (lstans != -1) v ^= lstans, x ^= lstans, k ^= lstans;
Forr(i, 18, 0) if (hh[F[i][v]] <= x) v = F[i][v];
int res = tr[rt[ed[v]]].v - tr[rt[st[v] - 1]].v;
if (res < k) puts("-1"), lstans = -1;
else {
lstans = ls[query(rt[st[v] - 1], rt[ed[v]], 1, tot, res - k + 1)];
printf("%d\n" ,lstans);
}
}
return 0;
}
【BZOJ3551】【BZOJ3545】 【ONTAK2010】 Peaks (kruskal重构树+主席树)的更多相关文章
- BZOJ3545&3551[ONTAK2010]Peaks——kruskal重构树+主席树+dfs序+树上倍增
题目描述 在Bytemountains有N座山峰,每座山峰有他的高度h_i.有些山峰之间有双向道路相连,共M条路径,每条路径有一个困难值,这个值越大表示越难走,现在有Q组询问,每组询问询问从点v开始只 ...
- 【BZOJ3545】Peaks(Kruskal重构树 主席树)
题目链接 大意 给出有\(N\)个点\(M\)条边的一张图,其中每个点都有一个High值,每条边都有一个Hard值. 再给出\(Q\)个询问:\(v\) \(x\) \(k\) 每次询问查询从点\(v ...
- luogu4197 Peaks (kruskal重构树+主席树)
按照边权排序建出kruskal重构树,每次就变成了先找一个权值<=x的最远的祖先,然后看这个子树的第k小.离散化一下,在dfs序上做主席树即可 而且只需要建叶节点的主席树 注意输出的是第k小点的 ...
- 洛谷P4197 Peaks(Kruskal重构树 主席树)
题意 题目链接 往后中文题就不翻译了qwq Sol 又是码农题..出题人这是强行把Kruskal重构树和主席树拼一块了啊.. 首先由于给出的限制条件是<=x,因此我们在最小生成树上走一定是最优的 ...
- [ONTAK2010]Peaks kruskal重构树,主席树
[ONTAK2010]Peaks kruskal重构树练手题. LG传送门竟然不强制在线?看到离线水过很不爽:B站强制在线版传送门 看到"询问从点\(v\)开始只经过困难值小于等于\(x\) ...
- luoguP4197:Peaks(Kruskal重构树+主席树)或者(点分树+离线)
题意:有N座山,M条道路.山有山高,路有困难值(即点权和边权).现在Q次询问,每次给出(v,p),让求从v出发,只能结果边权<=p的边,问能够到达的山中,第K高的高度(从大到小排序). 思路:显 ...
- [BZOJ3551][ONTAK2010]Peaks(加强版)(Kruskal重构树,主席树)
3551: [ONTAK2010]Peaks加强版 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 2438 Solved: 763[Submit][ ...
- 【BZOJ-3545&3551】Peaks&加强版 Kruskal重构树 + 主席树 + DFS序 + 倍增
3545: [ONTAK2010]Peaks Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1202 Solved: 321[Submit][Sta ...
- bzoj 3545: [ONTAK2010]Peaks Kruskal重构树
题目: 在Bytemountains有N座山峰,每座山峰有他的高度h_i.有些山峰之间有双向道路相连,共M条路径,每条路径有一个困难值,这个值越大表示越难走,现在有Q组询问,每组询问询问从点v开始只经 ...
随机推荐
- 安全提示:IIS不要开启“WebDAV”扩展(转载)
在IIS设置里,有一个“Web服务扩展”的设置,其中包括“WebDAV”扩展.许多人都不明白,这个“WebDAV”扩展是干嘛用的,要不要开启呢?有不少人的想法是“开启吧,以免影响网站运行,启用总比不启 ...
- Struts学习总结-02 上传文件
Struts 2框架提供了内置支持处理文件上传使用基于HTML表单的文件上传.上传一个文件时,它通常会被存储在一个临时目录中,他们应该由Action类进行处理或移动到一个永久的目录,以确保数据不丢失. ...
- Newtonsoft的序列化和反序列化
class test { public string a; public int b; public byte[] c; public In ...
- P4770 [NOI2018]你的名字
蒟蒻表示不会sam凉凉了,所以只能提高SA技巧? 题意:有一个串\(A\),每次选择一个\(A\)的子串\(A'\),以及串\(B\),问\(B\)的所有本质不同子串中不在\(A'\)中的串的数量. ...
- [HAOI2017]方案数[组合计数、容斥、dp]
题意 题目链接 分析 先考虑没有障碍怎么做,定义 f(i,j,k) 每一维走了 i,j,k 位的方案数,转移乘个组合数即可. 现在多了一些障碍,考虑容斥.实际我们走过的点都有严格的大小关系,所以先把所 ...
- 谈谈ThreadLocal的设计及不足
用Java语言开发的同学对 ThreadLocal 应该都不会陌生,这个类的使用场景很多,特别是在一些框架中经常用到,比如数据库事务操作,还有MVC框架中数据跨层传递.这里我们简要探讨下 Thread ...
- 关于EasyUI datagrid 无法在dialog中显示的问题分析及解决方案!
最近项目中引用了easyUI,很大程度上的简化了开发过程,但是随之而来的也遇到一些问题,比如:标题中遇到的问题,去网上搜罗了下关于这个问题的解决方案,不是说的很复杂就是干脆文不对题,国外的使用这种稍微 ...
- React.js 开发参见问题 Q&A
文章中我整理了 React.js 开发过程中一些参见问题的解答汇总,供大家参考. 1. 一些课程资源 课程完整的思维导图请查考文章:React.js 入门与实战课程思维导图,我使用的思维导图软件是 M ...
- Linux实验四报告
张文俊 + 原创作品转载请注明出处+ <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 一.学习内容 系统 ...
- linux 第七周 总结及实验
姬梦馨 原创作品 <Linux内核分析>MOOC课程http://mooc.study.163.com/course/USTC-1000029000 第七周 Linux内核如何装载和启动一 ...