BZOJ 3551 Peaks加强版
题目链接:http://www.lydsy.com/JudgeOnline/problem.php?id=3551
题意:给出一个图,n个点,m条边。边有权值点也有权值。若干询问,(v,x,k),问从v点开始经过边权不大于x的所有边到达的所有点中权值第K大的权值。强制在线。
思路:首先不在最小生成树上的边没用。将边权按照升序排序,并查集每次合并两个集合(x,y)时,新增一个点u,u的权值为这条边的权值,连有向边<u,x><u,y>。那么最后的这棵树是一个二叉树,从下到上权值增大。那么每次倍增求出最上的点r,那么以r为根的子树包含的所有点就是通过不大于x的所有边到达的点。因此dfs序+主席树(按照键值大小),那么每次查询r管辖的区间即可。
const int N=200005;
int n,h[N],b[N];
pair<int,pair<int,int> > E[N*3];
int m,Q;
int S[N];
int M;
int get(int x)
{
if(S[x]!=x) S[x]=get(S[x]);
return S[x];
}
vector<int> g[N];
int mp[N<<1],id;
int visit[N];
int st[N],ed[N];
int f[N][20],Max[N][20];
int eLen[N];
void DFS(int u)
{
visit[u]=1;
mp[++id]=u;
int i;
for(i=0;i<SZ(g[u]);i++)
{
int v=g[u][i];
f[v][0]=u;
Max[v][0]=eLen[u];
DFS(v);
}
if(u>n) mp[++id]=u;
}
struct node
{
int lson,rson,sum;
};
node a[N*25];
int e;
int root[N<<1];
int build(int L,int R)
{
int t=++e;
a[t].lson=a[t].rson=-1;
a[t].sum=0;
if(L==R) return t;
int M=(L+R)>>1;
a[t].lson=build(L,M);
a[t].rson=build(M+1,R);
return t;
}
void insert(int &t1,int t,int L,int R,int h)
{
t1=++e;
a[t1]=a[t];
a[t1].sum++;
if(L==R) return;
int M=(L+R)>>1;
if(h<=M) insert(a[t1].lson,a[t].lson,L,M,h);
else insert(a[t1].rson,a[t].rson,M+1,R,h);
}
int get(int u,int x)
{
int i;
for(i=19;i>=0;i--) if(f[u][i]&&Max[u][i]<=x)
{
u=f[u][i];
}
return u;
}
int query(int rt1,int rt2,int L,int R,int k)
{
if(L==R) return L;
int tmp=a[a[rt2].lson].sum-a[a[rt1].lson].sum;
int M=(L+R)>>1;
if(tmp>=k) return query(a[rt1].lson,a[rt2].lson,L,M,k);
else return query(a[rt1].rson,a[rt2].rson,M+1,R,k-tmp);
}
int main()
{
n=getInt();
m=getInt();
Q=getInt();
int i;
for(i=1;i<=n;i++) h[i]=b[i]=getInt();
sort(b+1,b+n+1);
M=unique(b+1,b+n+1)-(b+1);
for(i=1;i<=n;i++) h[i]=lower_bound(b+1,b+M+1,h[i])-b;
for(i=1;i<=n+n;i++) S[i]=i;
for(i=1;i<=m;i++)
{
int u=getInt();
int v=getInt();
int w=getInt();
E[i]=MP(w,MP(u,v));
}
sort(E+1,E+m+1);
int cur=n;
for(i=1;i<=m;i++)
{
int u=E[i].second.first;
int v=E[i].second.second;
int w=E[i].first;
if(get(u)==get(v)) continue;
u=get(u);
v=get(v);
cur++;
S[get(u)]=S[get(v)]=cur;
g[cur].pb(u);
g[cur].pb(v);
eLen[cur]=w;
}
for(i=1;i<=n;i++) if(!visit[i]) DFS(get(i));
int j;
for(i=1;(1<<i)<=cur;i++) for(j=1;j<=cur;j++)
{
f[j][i]=f[f[j][i-1]][i-1];
Max[j][i]=max(Max[j][i-1],Max[f[j][i-1]][i-1]);
}
clr(root,-1);
root[0]=build(1,M);
for(i=1;i<=id;i++)
{
int u=mp[i];
if(u<=n) insert(root[i],root[i-1],1,M,h[u]);
else
{
root[i]=root[i-1];
if(st[u]==0) st[u]=i;
else ed[u]=i;
}
}
int ans=0;
while(Q--)
{
int v=getInt();
int x=getInt();
int k=getInt();
if(-1!=ans) v^=ans,x^=ans,k^=ans;
int t=get(v,x);
int L=st[t],R=ed[t];
int cnt=a[root[R]].sum-a[root[L]].sum;
if(cnt<k) ans=-1;
else ans=b[query(root[L],root[R],1,M,cnt+1-k)];
printf("%d\n",ans);
}
}
BZOJ 3551 Peaks加强版的更多相关文章
- Peaks BZOJ 3545 / Peaks加强版 BZOJ 3551
Peaks [问题描述] 在Bytemountains有N座山峰,每座山峰有他的高度h_i.有些山峰之间有双向道路相连,共M条路径,每条路径有一个困难值,这个值越大表示越难走,现在有Q组询问,每组询问 ...
- bzoj 3545&&3551: [ONTAK2010]Peaks &&加强版 平衡树&&并查集合并树&&主席树
3545: [ONTAK2010]Peaks Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 635 Solved: 177[Submit][Stat ...
- BZOJ 3551: [ONTAK2010]Peaks加强版 [Kruskal重构树 dfs序 主席树]
3551: [ONTAK2010]Peaks加强版 题意:带权图,多组询问与一个点通过边权\(\le lim\)的边连通的点中点权k大值,强制在线 PoPoQQQ大爷题解传送门 说一下感受: 容易发现 ...
- 【BZOJ-3545&3551】Peaks&加强版 Kruskal重构树 + 主席树 + DFS序 + 倍增
3545: [ONTAK2010]Peaks Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 1202 Solved: 321[Submit][Sta ...
- 3551: [ONTAK2010]Peaks加强版
3551: [ONTAK2010]Peaks加强版 https://www.lydsy.com/JudgeOnline/problem.php?id=3551 分析: kruskal重构树 + 倍增 ...
- 【BZOJ3551】 [ONTAK2010]Peaks加强版
BZOJ3551 [ONTAK2010]Peaks加强版 Solution Kruscal重构树后发现可以对于小于的离散化然后倍增+主席树找到上一个的可行解. 然后就可以了. 如果数组开的不好,容易在 ...
- 【BZOJ3551】Peaks加强版(Kruskal重构树,主席树)
[BZOJ3551]Peaks加强版(Kruskal重构树,主席树) 题面 BZOJ Description 在Bytemountains有N座山峰,每座山峰有他的高度h_i.有些山峰之间有双向道路相 ...
- 【BZOJ3551】[ONTAK2010]Peaks加强版 最小生成树+DFS序+主席树
[BZOJ3545][ONTAK2010]Peaks Description 在Bytemountains有N座山峰,每座山峰有他的高度h_i.有些山峰之间有双向道路相连,共M条路径,每条路径有一个困 ...
- [BZOJ3551][ONTAK2010]Peaks(加强版)(Kruskal重构树,主席树)
3551: [ONTAK2010]Peaks加强版 Time Limit: 20 Sec Memory Limit: 128 MBSubmit: 2438 Solved: 763[Submit][ ...
随机推荐
- 夺命雷公狗---node.js---15之加密
node其实也给我们留下了密码的加密发送,不过一般都是用cmd5加密其实也是够了,但是sha1加密也要提下: /** * Created by leigood on 2016/8/31. */ var ...
- 夺命雷公狗ThinkPHP项目之----企业网站22之网站前台中间层(解决代码冗余)
我们如果这样写代码虽然可以实现头部二级分类的显示,但是如果再别的控制器下那么会出现显示不了.. 如果再加多一段一样的代码也可以实现出一样的效果: 但是这样会导致代码冗余现象,所以我们为了解决这个问题, ...
- php获取网页中图片并保存到本地
php获取网页中图片并保存到本地的代码,将网页中图片保存本地文件夹: save_img("http://www.jbxue.com" ?>
- 使用javascript判断浏览器对css3的支持情况【译】
Quick Tip: Detect CSS3 Support in Browsers with JavaScript Jeffrey Way on Nov 15th 2010 步骤 1 首先我们要确 ...
- COM编程之五 动静态链接
[1]静态链接 静态链接是指由链接器在链接时将库的内容加入到可执行程序中的做法. 链接器是一个独立程序,将一个或多个库或目标文件(先前由编译器或汇编器生成)链接到一块生成可执行程序. 函数和数据被编译 ...
- Android NDK 开发(一)--环境搭建【转】
转载请注明出处:http://blog.csdn.net/allen315410/article/details/41800955 Android下的NDK开发是Android开发中不可或缺的一部分, ...
- dojo/dom dojo/domConstruct dojo/query
dom.byId require(["dojo/dom", "dojo/domReady!"], function(dom) { var one = dom.b ...
- oracle 11g升级
手先需要下载oracle11g的补丁安装包,一般只有付费用户才能获取到该安装包,其他用户获取不到,那怎么办呢? 万能的互联网可以办到,可以用http://www.wangpansou.cn/所有其他用 ...
- linux中Iptables限制同一IP连接数防CC/DDOS攻击方法
1.限制与80端口连接的IP最大连接数为10,可自定义修改. 代码如下 复制代码 iptables -I INPUT -p tcp --dport 80 -m connlimit --connlim ...
- Effective C++第三遍
试图调用private的copy或赋值函数是编译期错误,而调用没有具体定义的函数则是连接期错误. 以对象管理资源:智能指针RAII(资源获取立即初始化)后都是对象,但有时候,比如(API的)函数参数要 ...