[BZOJ3551]Peaks

BZOJ

luogu

建Kruskal重构树,点权为边权

按dfn序建出主席树

倍增找到能跳到的最浅的祖先

主席树查询一下

#include<bits/stdc++.h>
using namespace std;
const int N=1e5+5,M=5e5+5;
int re(){
int x=0,w=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')w=-1;ch=getchar();}
while(ch>='0'&&ch<='9')x=x*10+ch-'0',ch=getchar();
return x*w;
}
int n,m,q,cnt,S,tot,ts,len,ans;
int he[N],o[N],h[N<<1],val[N<<1],dfn[N<<1],sz[N<<1],dep[N<<1],fa[N<<1];
int f[20][N<<1],rt[N<<1],s[N<<5],ls[N<<5],rs[N<<5];
struct Edge{int u,v,w;}E[M];
struct edge{int to,next;}e[M<<2];
bool cmp(Edge a,Edge b){return a.w<b.w;}
int find(int x){return x==fa[x]?x:fa[x]=find(fa[x]);}
void link(int u,int v){
e[++cnt]=(edge){v,h[u]};h[u]=cnt;
e[++cnt]=(edge){u,h[v]};h[v]=cnt;
}
void add(int&x,int l,int r,int v){
s[++S]=s[x]+1;ls[S]=ls[x];rs[S]=rs[x];
x=S;if(l==r)return;int mid=(l+r)>>1;
if(v<=mid)add(ls[x],l,mid,v);
else add(rs[x],mid+1,r,v);
}
int qkth(int x,int y,int l,int r,int k){
if(l==r)return l;
int mid=(l+r)>>1,Sz=s[rs[y]]-s[rs[x]];
if(k<=Sz)return qkth(rs[x],rs[y],mid+1,r,k);
return qkth(ls[x],ls[y],l,mid,k-Sz);
}
void dfs(int u){
dfn[u]=++ts;sz[u]=1;
if(f[0][u])rt[ts]=rt[ts-1];
if(u<=n)add(rt[ts],1,len,he[u]);
for(int i=h[u];i;i=e[i].next){
int v=e[i].to;
if(v==f[0][u])continue;
f[0][v]=u;dep[v]=dep[u]+1;
dfs(v);sz[u]+=sz[v];
}
}
int main(){
tot=n=re(),m=re(),q=re();
for(int i=1;i<=n;i++)o[i]=he[i]=re();
sort(o+1,o+n+1);
len=unique(o+1,o+n+1)-o-1;
for(int i=1;i<=n;i++)
he[i]=lower_bound(o+1,o+len+1,he[i])-o;
for(int i=1;i<=n<<1;i++)fa[i]=i;
for(int i=1;i<=m;i++)
E[i].u=re(),E[i].v=re(),E[i].w=re();
sort(E+1,E+m+1,cmp);
for(int i=1;i<=m;i++){
int x=find(E[i].u),y=find(E[i].v);
if(x==y)continue;val[++tot]=E[i].w;
link(tot,x);link(tot,y);fa[x]=fa[y]=tot;
}
for(int i=1;i<=tot;i++)
if(!dfn[i])dfs(find(i));
for(int i=1;i<=18;i++)
for(int j=1;j<=tot;j++)
f[i][j]=f[i-1][f[i-1][j]];
while(q--){
int u=re()^ans,x=re()^ans,k=re()^ans;
for(int i=18;i>=0;i--)
if(f[i][u]&&val[f[i][u]]<=x)u=f[i][u];
int A=rt[dfn[u]-1],B=rt[dfn[u]+sz[u]-1];
if(s[B]-s[A]<k)puts("-1"),ans=0;
else printf("%d\n",ans=o[qkth(A,B,1,len,k)]);
}
return 0;
}

[BZOJ3551]Peaks的更多相关文章

  1. bzoj3551 Peaks加强版

    这个题--感觉离线和在线的代码难度差不多(pb_ds不要说话). 离线的话,就是把所有询问按照w排个序,然后一边Kruskal+平衡树启发式合并一边回答询问就好了. 在线也不难写.首先Kruskal重 ...

  2. 2018.09.30 bzoj3551:Peaks加强版(dfs序+主席树+倍增+kruskal重构树)

    传送门 一道考察比较全面的题. 这道题又用到了熟悉的kruskal+倍增来查找询问区间的方法. 查到询问的子树之后就可以用dfs序+主席树统计答案了. 代码: #include<bits/std ...

  3. BZOJ3551 Peaks加强版 [Kruskal重构树,主席树]

    BZOJ 思路 我觉得这题可持久化线段树合并也可以做 我觉得这题建出最小生成树之后动态点分治+线段树也可以做 还是学习一下Kruskal重构树吧-- Kruskal重构树,就是在做最小生成树的时候,如 ...

  4. [您有新的未分配科技点][BZOJ3545&BZOJ3551]克鲁斯卡尔重构树

    这次我们来搞一个很新奇的知识点:克鲁斯卡尔重构树.它也是一种图,是克鲁斯卡尔算法求最小生成树的升级版首先看下面一个问题:BZOJ3545 Peaks. 在Bytemountains有N座山峰,每座山峰 ...

  5. 【BZOJ3551】 [ONTAK2010]Peaks加强版

    BZOJ3551 [ONTAK2010]Peaks加强版 Solution Kruscal重构树后发现可以对于小于的离散化然后倍增+主席树找到上一个的可行解. 然后就可以了. 如果数组开的不好,容易在 ...

  6. 【BZOJ3551】Peaks加强版(Kruskal重构树,主席树)

    [BZOJ3551]Peaks加强版(Kruskal重构树,主席树) 题面 BZOJ Description 在Bytemountains有N座山峰,每座山峰有他的高度h_i.有些山峰之间有双向道路相 ...

  7. 【BZOJ3551】[ONTAK2010]Peaks加强版 最小生成树+DFS序+主席树

    [BZOJ3545][ONTAK2010]Peaks Description 在Bytemountains有N座山峰,每座山峰有他的高度h_i.有些山峰之间有双向道路相连,共M条路径,每条路径有一个困 ...

  8. [BZOJ3551][ONTAK2010]Peaks(加强版)(Kruskal重构树,主席树)

    3551: [ONTAK2010]Peaks加强版 Time Limit: 20 Sec  Memory Limit: 128 MBSubmit: 2438  Solved: 763[Submit][ ...

  9. bzoj3545/bzoj3551 [ONTAK2010]Peaks/Peaks加强版

    bzoj3545/bzoj3551 [ONTAK2010]Peaks/Peaks加强版 传送门:bzoj  bzoj wdnmd为什么加强版不是权限题原题却是啊 3545: [ONTAK2010]Pe ...

随机推荐

  1. 软件质量特征 ISO9126

    ISO/IEC9126软件质量模型是一种评价软件质量的通用模型,包括3个层次: 1.质量特性 2.质量子特性 3.度量指标 其中各六个质量特性与二十七个质量子特性的关系如下表: 1.功能性 是指当软件 ...

  2. JPA联合主键@EmbeddedId使用详解附查询例子

    花了2个小时的时间解决这个问题,网上资料太少,记录下     详情看源文件TBicPrmCompute,TBicPrmComputePK package com.isoftstone.core.dom ...

  3. asp.net+mvc+easyui+sqlite 简单用户系统学习之旅(三)—— 简单登录页面+sqlite+动软代码生成器的使用

    上一节讲到利用easyui的layout.tree.tab和datagrid创建用户管理的页面,注意利用到easyui的页面一定要按顺序添加jQuery和easyUI的.js和.css样式,灵活查看e ...

  4. UIAlertViewController 2

    iOS 8的新特性之一就是让接口更有适应性.更灵活,因此许多视图控制器的实现方式发生了巨大的变化.全新的UIPresentationController在实现视图控制器间的过渡动画效果和自适应设备尺寸 ...

  5. Hackerrank - Game Of Rotation 题解

    旋转一个数组以得到最大值. 陷阱就是:不能排序.须要模拟操作旋转,并设计公式计算旋转后的和. 要求是O(n)时间完毕. 原题: https://www.hackerrank.com/challenge ...

  6. web 图片上传实现本地预览

    在说上传之前先说说如何替换or美化浏览器自带的简陋上传按钮(自定义自己的上传按钮 如:img): 1.将自定义上传按钮上方添加 input file 框,实现input实现透明处理. 2.对自定义上传 ...

  7. MySQL 慢查询日志(Slow Query Log)

    同大多数关系型数据库一样.日志文件是MySQL数据库的重要组成部分.MySQL有几种不同的日志文件.通常包含错误日志文件,二进制日志,通用日志.慢查询日志.等等.这些日志能够帮助我们定位mysqld内 ...

  8. php-fpm用socket连接

    总结:在最新nginx.php下实践如下: 第一步:添加php5-fpm.sock文件 cd /var/run sudo vim php5-fpm.sock  //啥也不写入,只要这个文件就可以了~ ...

  9. spark-streaming的checkpoint机制源码分析

    转发请注明原创地址 http://www.cnblogs.com/dongxiao-yang/p/7994357.html spark-streaming定时对 DStreamGraph 和 JobS ...

  10. 生产环境中 Ngx_lua 使用技巧和应用的范例

    生产环境中 Ngx_lua 使用技巧和应用的范例 时间 -- :: 51CTO技术博客 原文 http://rfyiamcool.blog.51cto.com/1030776/1252501 主题 L ...