bzoj3545/bzoj3551 [ONTAK2010]Peaks/Peaks加强版
bzoj3545/bzoj3551 [ONTAK2010]Peaks/Peaks加强版
wdnmd为什么加强版不是权限题原题却是啊
3545: [ONTAK2010]Peaks
Time Limit: 10 Sec Memory Limit: 128 MB
[Submit][Status][Discuss]
Description
在Bytemountains有N座山峰,每座山峰有他的高度h_i。有些山峰之间有双向道路相连,共M条路径,每条路径有一个困难值,这个值越大表示越难走,现在有Q组询问,每组询问询问从点v开始只经过困难值小于等于x的路径所能到达的山峰中第k高的山峰,如果无解输出-1。
Input
第一行三个数N,M,Q。
第二行N个数,第i个数为h_i
接下来M行,每行3个数a b c,表示从a到b有一条困难值为c的双向路径。
接下来Q行,每行三个数v x k,表示一组询问。
Output
对于每组询问,输出一个整数表示答案。
Sample Input
1 2 3 4 5 6 7 8 9 10
1 4 4
2 5 3
9 8 2
7 8 10
7 1 4
6 7 1
6 4 8
2 1 5
10 8 10
3 4 7
3 4 6
1 5 2
1 5 6
1 5 8
8 9 2
Sample Output
1
-1
8
HINT
【数据范围】
N<=10^5, M,Q<=5*10^5,h_i,c,x<=10^9。
果然还是太年轻了居然被这种水平的题吊打。。。
简短思路:
首先来一次kruskal
很明显不在树上的边都用不上
然后这时候就出现了kruskal重构树
拼出来重构树之后用线段树合并或是主席树都行
以下通用代码(只差一排注释)
1 #include<cstdio>
2 #include<algorithm>
3 #include<cstring>
4 using namespace std;
5 const int N=200011,inf=0x7f7f7f7f,M=500011;
6 template<typename TP>inline void read(TP &kk)
7 {
8 TP ret=0,f=1;char ch=getchar();
9 while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
10 while(ch>='0'&&ch<='9'){ret=ret*10+ch-'0';ch=getchar();}
11 kk=ret*f;
12 }
13 int n,m,Q;
14 struct shino
15 {
16 int x,y,w;
17 bool operator < (const shino &a)const
18 {return w<a.w;}
19 }sl[M];
20 int snr;
21 #define lson(x) (son[x][0])
22 #define rson(x) (son[x][1])
23 struct sgt
24 {
25 int c[N*36],son[N*36][2],cnt;
26 void ins(const int x,int &px,int pl,int pr)
27 {
28 if(!px) px=++cnt;
29 c[px]++;
30 if(pl==pr) return;
31 int mi=pl+pr>>1;
32 if(x<=mi) ins(x,lson(px),pl,mi);
33 else ins(x,rson(px),mi+1,pr);
34 }
35 int merge(const int px,const int py)
36 {
37 if(!px||!py) return px+py;
38 int pz=++cnt;
39 c[pz]=c[px]+c[py];
40 lson(pz)=merge(lson(px),lson(py));
41 rson(pz)=merge(rson(px),rson(py));
42 return pz;
43 }
44 int query(int k,const int px,int pl,int pr)
45 {
46 if(pl==pr) return pl;
47 int mi=pl+pr>>1;
48 if(k<=c[lson(px)]) return query(k,lson(px),pl,mi);
49 else return query(k-c[lson(px)],rson(px),mi+1,pr);
50 }
51 }tr;
52 int rt[N];
53 int h[N];
54 int f[N],fa[N][20],val[N],son[N][2];
55 int find(int x)
56 {
57 if(f[x]!=f[f[x]]) return f[x]=find(f[x]);
58 return f[x];
59 }
60 void kksk()//k,k(ru)sk(al)... 无端玩梗的rkk是屑
61 {
62 snr=n,val[0]=inf;
63 for(int i=1;i<=m;i++)
64 {
65 int x=find(sl[i].x),y=find(sl[i].y);
66 if(x==y) continue;
67 f[x]=f[y]=fa[x][0]=fa[y][0]=++snr;
68 val[snr]=sl[i].w;
69 son[snr][0]=x,son[snr][1]=y;
70 }
71 }
72
73 int saki[N];
74 int main()
75 {
76 read(n),read(m),read(Q);
77 for(int i=1;i<=n;i++)
78 read(sl[i].w),sl[i].x=i;
79 sort(sl+1,sl+1+n);
80 for(int i=1;i<=n;i++)
81 {
82 if(sl[i].w!=sl[i-1].w) saki[++snr]=sl[i].w;
83 h[sl[i].x]=snr;
84 }
85 for(int i=1;i<=m;i++)
86 read(sl[i].x),read(sl[i].y),read(sl[i].w);
87 sort(sl+1,sl+1+m);
88 for(int i=1;i<=n*2;i++) f[i]=i;
89 kksk();
90 for(int i=1;i<=19;i++)
91 for(int x=1;x<=snr;x++)
92 fa[x][i]=fa[fa[x][i-1]][i-1];
93 for(int i=1;i<=n;i++) tr.ins(h[i],rt[i],1,n);
94 for(int i=n+1;i<=n*2;i++) rt[i]=tr.merge(rt[lson(i)],rt[rson(i)]);
95 int lans=0,xi,vi,ki;
96 while(Q--)
97 {
98 read(xi),read(vi),read(ki);
99 xi^=lans,vi^=lans,ki^=lans;//前后就差个这行
100 for(int i=19;i>=0;i--)
101 {
102 if(val[fa[xi][i]]<=vi) xi=fa[xi][i];
103 }
104 if(tr.c[rt[xi]]<ki){puts("-1");lans=0;}
105 else printf("%d\n",lans=saki[tr.query(tr.c[rt[xi]]-ki+1,rt[xi],1,n)]);
106 }
107 return 0;
108 }
bzoj3545/bzoj3551 [ONTAK2010]Peaks/Peaks加强版的更多相关文章
- 【bzoj3545】[ONTAK2010]Peaks 线段树合并
[bzoj3545][ONTAK2010]Peaks 2014年8月26日3,1512 Description 在Bytemountains有N座山峰,每座山峰有他的高度h_i.有些山峰之间有双向道路 ...
- 「BZOJ3545」「ONTAK2010」Peaks
「BZOJ3545」「ONTAK2010」Peaks 题目传送门 题目大意: 给定一个 \(n\) 个点,\(m\) 条边的带点权边权无向图,有 \(q\) 次询问,每次询问从 \(v\) 点出发,经 ...
- 【bzoj3545/bzoj3551】[ONTAK2010]Peaks/加强版 Kruskal+树上倍增+Dfs序+主席树
bzoj3545 题目描述 在Bytemountains有N座山峰,每座山峰有他的高度h_i.有些山峰之间有双向道路相连,共M条路径,每条路径有一个困难值,这个值越大表示越难走,现在有Q组询问,每组询 ...
- bzoj3545 [ONTAK2010]Peaks、bzoj3551 [ONTAK2010]Peaks加强版
题目描述: bzoj3545,luogu bzoj3551 题解: 重构树+线段树合并. 可以算是板子了吧. 代码(非强制在线): #include<cstdio> #include< ...
- [BZOJ3551][ONTAK2010]Peaks(加强版)(Kruskal重构树,主席树)
3551: [ONTAK2010]Peaks加强版 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 2438 Solved: 763[Submit][ ...
- 【BZOJ3551】【BZOJ3545】 【ONTAK2010】 Peaks (kruskal重构树+主席树)
Description 在\(Bytemountains\)有\(~n~\)座山峰,每座山峰有他的高度\(~h_i~\). 有些山峰之间有双向道路相连,共\(~m~\)条路径,每条路径有一个困难值 ...
- BZOJ3551 [ONTAK2010]Peaks加强版 kruskal 并查集 主席树 dfs序
欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ3551 题意概括 Description 在Bytemountains有N座山峰,每座山峰有他的高度 ...
- BZOJ3551: [ONTAK2010]Peaks加强版【Kruskal重构树】【主席树】
重要的事情说三遍 不保证图联通 不保证图联通 不保证图联通 那些和我一样认为重构树是点数的童鞋是要GG Description [题目描述]同3545 Input 第一行三个数N,M,Q. 第二行N个 ...
- BZOJ3551 : [ONTAK2010]Peaks加强版
首先强制在线的话,肯定是不能再离线排序+平衡树启发式合并了. 这回要用的是线段树合并,每次把两棵线段树合并,总复杂度为$O(n\log n)$ 预处理: 把边按权值从小到大排序,依次加边, 对于边(x ...
随机推荐
- CobaltStrike逆向学习系列(3):Beacon C2Profile 解析
这是[信安成长计划]的第 3 篇文章 关注微信公众号[信安成长计划] 0x00 目录 0x01 Controller 端分析 0x02 Beacon 端分析 0x03 展示图 在上一篇文章中完成了 S ...
- vmware 16 pro 安装macos
VMware 16 安装 MAC OS 10.13 原版(详细图文教程)关于虚拟机安装苹果系统的教程网络上有很多, 有些适合自己, 有些则不适合(教程中的版本老旧或工具资源消失), 在安装成功后选择用 ...
- RENIX 软件如何进行IP地址管理——网络测试仪实操
本文主要介绍了BIGTAO网络测试仪如何通过RENIX软件进行IP地址管理.文章分为五部分内容,第一部分介绍了如何通过机框显示屏查看IP地址,之后几部分分别介绍了机框按钮修改.机框接显示器/键盘修改. ...
- 【C# 线程】 延迟初始化
1. 简介 1.延迟初始化出现于.NET 4.0,主要用于提高性能,避免浪费计算,并减少程序内存要求.也可以称为,按需加载. 2.从net 4.0开始,C#开始支持延迟初始化,通过Lazy关键字,我们 ...
- 【C#表达式树 开篇】 Expression Tree - 动态语言
.NET 3.5中新增的表达式树(Expression Tree)特性,第一次在.NET平台中引入了"逻辑即数据"的概念.也就是说,我们可以在代码里使用高级语言的形式编写一段逻辑, ...
- 【C# 基础概念】抽象类、密封类及类成员
使用 abstract 关键字可以创建不完整且必须在派生类中实现的类和 class 成员. 使用 sealed 关键字可以防止继承以前标记为 virtual 的类或某些类成员. abstract修饰符 ...
- JAVA只要掌握内部类,多继承和单继承都不是问题
摘要:如果实现java的多继承,其实很简单,关键是对于内部类的特征的掌握,内部类可以继承一个与外部类无关的类,保证了内部类天然独立性,根据这个特性从而实现一个类可以继承多个类的效果. 本文分享自华为云 ...
- hadoop分布式集群部署①
Linux系统的安装和配置.(在VM虚拟机上) 一:安装虚拟机VMware Workstation 14 Pro 以上,虚拟机软件安装完成. 二:创建虚拟机. 三:安装CentOS系统 (1)上面步 ...
- DDos攻击竟然这么恐怖,它的原理是什么?
DDOS的定义 分布式拒绝服务(DDoS:Distributed Denial of Service)攻击指借助于客户/服务器技术,将多个计算机联合起来作为攻击平台,对一个或多个目标发动DDoS攻击, ...
- spring源码干货分享-对象创建详细解析(set注入和初始化)
记录并分享一下本人学习spring源码的过程,有什么问题或者补充会持续更新.欢迎大家指正! 环境: spring5.X + idea 建议:学习过程中要开着源码一步一步过 Spring根据BeanDe ...