题目描述:

bzoj3545luogu

bzoj3551

题解:

重构树+线段树合并。

可以算是板子了吧。

代码(非强制在线):

#include<cstdio>
#include<cstring>
#include<algorithm>
using namespace std;
const int N = ;
const int M = *N;
template<typename T>
inline void read(T&x)
{
T f = ,c = ;char ch=getchar();
while(ch<''||ch>''){if(ch=='-')f=-;ch=getchar();}
while(ch>=''&&ch<=''){c=c*+ch-'';ch=getchar();}
x = f*c;
}
int n,m,q,to[N],h[N];
struct Pair
{
int x,y;
}p[N];
bool cmp(Pair a,Pair b){return a.x<b.x;}
struct Edge
{
int x,y,w;
void rd(){read(x),read(y),read(w);}
}d[M];
bool emp(Edge a,Edge b){return a.w<b.w;}
int ff[N<<],fa[N<<][],wg[N<<],ch[N<<][];
int findff(int u){return u==ff[u]?u:ff[u]=findff(ff[u]);}
void kru()
{
wg[] = 0x3f3f3f3f;
for(int i=;i<=(n<<);i++)ff[i] = i;
int tot = n,sum = ;
for(int i=;i<=m&&sum<n-;i++)
{
int x = findff(d[i].x),y = findff(d[i].y);
if(x!=y)
{
ff[x]=ff[y]=fa[x][]=fa[y][]=++tot;
wg[tot]=d[i].w;
sum++;
ch[tot][]=x,ch[tot][]=y;
}
}
}
void init()
{
for(int k=;(<<k)<=(n<<);k++)
for(int i=;i<(n<<);i++)
fa[i][k]=fa[fa[i][k-]][k-];
}
int rt[N<<];
struct segtree
{
int siz[*N],ls[*N],rs[*N],tot;
void insert(int l,int r,int&u,int qx)
{
if(!u)u=++tot;siz[u]++;
if(l==r)return ;
int mid = (l+r)>>;
if(qx<=mid)insert(l,mid,ls[u],qx);
else insert(mid+,r,rs[u],qx);
}
int merge(int x,int y)
{
if(!(x*y))return x+y;
int z = ++tot;
siz[z] = siz[x]+siz[y];
ls[z] = merge(ls[x],ls[y]);
rs[z] = merge(rs[x],rs[y]);
return z;
}
int query(int l,int r,int u,int qk)
{
if(l==r)return l;
int tmp = siz[rs[u]],mid = (l+r)>>;
if(qk<=tmp)return query(mid+,r,rs[u],qk);
else return query(l,mid,ls[u],qk-tmp);
}
}tr;
int main()
{
// freopen("tt.in","r",stdin);
read(n),read(m),read(q);
for(int i=;i<=n;i++)read(p[i].x),p[i].y=i;
sort(p+,p++n,cmp);
for(int las=0x3f3f3f3f,k=,i=;i<=n;i++)
{
if(las!=p[i].x)
{
las = p[i].x;
to[++k] = las;
}
h[p[i].y] = k;
}
for(int i=;i<=m;i++)d[i].rd();
sort(d+,d++m,emp);
kru();init();
for(int i=;i<=n;i++)tr.insert(,n,rt[i],h[i]);
for(int i=n+;i<(n<<);i++)rt[i]=tr.merge(rt[ch[i][]],rt[ch[i][]]);
for(int u,w,k,i=;i<=q;i++)
{
read(u),read(w),read(k);
for(int j=;j>=;j--)if(wg[fa[u][j]]<=w)u=fa[u][j];
if(tr.siz[rt[u]]<k)puts("-1");
else printf("%d\n",to[tr.query(,n,rt[u],k)]);
}
return ;
}

bzoj3545 [ONTAK2010]Peaks、bzoj3551 [ONTAK2010]Peaks加强版的更多相关文章

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

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

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

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

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

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

  4. BZOJ3551 [ONTAK2010]Peaks加强版 kruskal 并查集 主席树 dfs序

    欢迎访问~原文出处——博客园-zhouzhendong 去博客园看该题解 题目传送门 - BZOJ3551 题意概括 Description 在Bytemountains有N座山峰,每座山峰有他的高度 ...

  5. BZOJ3551: [ONTAK2010]Peaks加强版【Kruskal重构树】【主席树】

    重要的事情说三遍 不保证图联通 不保证图联通 不保证图联通 那些和我一样认为重构树是点数的童鞋是要GG Description [题目描述]同3545 Input 第一行三个数N,M,Q. 第二行N个 ...

  6. BZOJ3551 : [ONTAK2010]Peaks加强版

    首先强制在线的话,肯定是不能再离线排序+平衡树启发式合并了. 这回要用的是线段树合并,每次把两棵线段树合并,总复杂度为$O(n\log n)$ 预处理: 把边按权值从小到大排序,依次加边, 对于边(x ...

  7. 【BZOJ3545&BZOJ3551】Peaks(kruskal重构树,主席树,dfs序)

    题意:在Bytemountains有N座山峰,每座山峰有他的高度h_i. 有些山峰之间有双向道路相连,共M条路径,每条路径有一个困难值,这个值越大表示越难走, 现在有Q组询问,每组询问询问从点v开始只 ...

  8. Peaks BZOJ 3545 / Peaks加强版 BZOJ 3551

    Peaks [问题描述] 在Bytemountains有N座山峰,每座山峰有他的高度h_i.有些山峰之间有双向道路相连,共M条路径,每条路径有一个困难值,这个值越大表示越难走,现在有Q组询问,每组询问 ...

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

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

随机推荐

  1. Android近场通信---NFC基础(二)(转)

    转自 http://blog.csdn.net/think_soft/article/details/8171256 应用程序如何调度NFC标签 当标签调度系统完成对NFC标签和它的标识信息封装的In ...

  2. Java | 基础归纳 | trim()

    trim() 方法用于删除字符串的头尾空白符. 一般可以用来判断空白字符串的长度 String mName = “ ”: if(mName == null || mName.trim().length ...

  3. 使用top观察一进程的cpu历史占用情况

    #!/bin/shtop -b -n 1 -p 1975| tail -3 >>process1975.log 搞了时间节点,做个定时任务什么的就ok了

  4. 转 用好HugePage,告别Linux性能故障

    超过32G 的数据库,可以是使用如下方法配置. ######### Slow Performance with High CPU Usage on 64-bit Linux with Large SG ...

  5. Integer一类的比较问题

    总体主要分为两个方面 ①比较的是值 一.基本数据类型与引用数据类型进行比较时,引用数据类型会进行拆箱(自动拆装箱需要在jdk1.5以上),然后与基本数据类型进行值的比较 举例: int i = 12; ...

  6. 部署iis服务器与c#程序遇到的问题小结

    记得上次部署IIS服务器比较顺利,半天搞定的?有点忘了. 但,服务器版本各有不同,这次装的是server2008 R2 Ennterprice版.虽然忘了上次装的是哪个版本,但进去后发现有些东西明显不 ...

  7. 74HC14D(6反向施密特触发器)

    74HC14D:6反向施密特触发器:延迟特性,反向特性,整形特点. 施密特触发器是具有特殊功能的非门,当加在它的输入端A的电压逐渐上升到某个值时(正阈值电压),输出端Y会突然从高电平跳到低电平,而当输 ...

  8. python学习之内部函数:

    python内置函数表:https://docs.python.org/3/library/functions.html 1 判断数据类型的函数:isinstance(变量, 待要判断的类型) 2判断 ...

  9. jquery offsetParent()源码解读

    offsetParent: function() { return this.map(function() { var offsetParent = this.offsetParent || docE ...

  10. Java面试:投行的15个多线程和并发面试题(转)

    多线程和并发问题已成为各种 Java 面试中必不可少的一部分.如果你准备参加投行的 Java 开发岗位面试,比如巴克莱银行(Barclays).花旗银行(Citibank).摩根史坦利投资公司(Mor ...