平衡树+启发式合并+并查集

  因为要求一坨数中第k大的……用平衡树会很好维护……

  但又要求连通块?所以用并查集来维护……

  大概就是让并查集的fa和Treap的根是同一个节点吧……

TLE了N多发,可能是Treap的随机rank看脸的原因……QAQ

唯一过了的一次是小号……

 /**************************************************************
Problem: 2733
User: ProgrammingApe
Language: C++
Result: Accepted
Time:2356 ms
Memory:3640 kb
****************************************************************/ //BZOJ 2733
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<iostream>
#include<algorithm>
#define rep(i,n) for(int i=0;i<n;++i)
#define F(i,j,n) for(int i=j;i<=n;++i)
#define D(i,j,n) for(int i=j;i>=n;--i)
using namespace std; inline int getint(){
int v=,sign=; char ch=getchar();
while(ch<''||ch>'') {if (ch=='-') sign=-; ch=getchar();}
while(ch>=''&&ch<='') {v=v*+ch-''; ch=getchar();}
return v*=sign;
}
/*******************tamplate********************/
const int N=;
struct node{
int ch[];
int rk,v,size;
node(){}
#define L t[o].ch[0]
#define R t[o].ch[1]
}t[N];
int fa[N],n;
int getfa(int x){ return fa[x]==x ? x : getfa(fa[x]); }
inline void push_up(int o){
t[o].size=t[L].size+t[R].size+;
}
inline void rotate(int &o,int d){
int k=t[o].ch[!d];
t[o].ch[!d]=t[k].ch[d];
t[k].ch[d]=o;
push_up(o);
o=k;
}
inline void insert(int &o,int x){
if (!o){
o=x; t[o].size=; L=R=;
t[o].rk=rand();
}
else{
t[o].size++;
if (t[x].v<t[o].v){
insert(L,x);
if (t[L].rk<t[o].rk) rotate(o,);
}
else{
insert(R,x);
if (t[R].rk<t[o].rk) rotate(o,);
}
push_up(o);
}
}
inline void merge(int x,int y){//将x向y合并
if (x==) return;
merge(t[x].ch[],y); merge(t[x].ch[],y);
insert(y,x);
}
inline void solvemerge(){
int x=getint(), y=getint();
int f1=getfa(x),f2=getfa(y);
if (f1==f2) return;
if (t[f1].size>t[f2].size) swap(f1,f2);
fa[f1]=f2;
merge(f1,f2);
}
inline int kth(int o,int k){
while(o){
if (!o || k<= || k>t[o].size) return -;
int s=t[L].size;
if (k==s+) return o;
else if (k<=s) o=L;
else {o=R; k=k-s-;}
}
return -;
}
int main(){
n=getint();
int m=getint(),x,y;
F(i,,n){
t[i].v=getint();
fa[i]=i; t[i].size=; t[i].ch[]=t[i].ch[]=;
}
F(i,,m) solvemerge();
int q=getint();
char cmd[];
F(i,,q){
scanf("%s",cmd);
if (cmd[]=='Q'){
x=getint(); y=getint();
int f1=getfa(x);
printf("%d\n",kth(f1,y));
}
else solvemerge();
}
return ;
}

【BZOJ】【2733】【HNOI2012】永无乡的更多相关文章

  1. BZOJ 2733: [HNOI2012]永无乡 启发式合并treap

    2733: [HNOI2012]永无乡 Time Limit: 20 Sec Memory Limit: 256 MB 题目连接 http://www.lydsy.com/JudgeOnline/pr ...

  2. bzoj 2733: [HNOI2012]永无乡 离线+主席树

    2733: [HNOI2012]永无乡 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 1167  Solved: 607[Submit][Status ...

  3. BZOJ 2733: [HNOI2012]永无乡(treap + 启发式合并 + 并查集)

    不难...treap + 启发式合并 + 并查集 搞搞就行了 --------------------------------------------------------------------- ...

  4. BZOJ 2733: [HNOI2012]永无乡 [splay启发式合并]

    2733: [HNOI2012]永无乡 题意:加边,询问一个连通块中k小值 终于写了一下splay启发式合并 本题直接splay上一个节点对应图上一个点就可以了 并查集维护连通性 合并的时候,把siz ...

  5. bzoj 2733: [HNOI2012]永无乡 -- 线段树

    2733: [HNOI2012]永无乡 Time Limit: 10 Sec  Memory Limit: 128 MB Description 永无乡包含 n 座岛,编号从 1 到 n,每座岛都有自 ...

  6. Bzoj 2733: [HNOI2012]永无乡 数组Splay+启发式合并

    2733: [HNOI2012]永无乡 Time Limit: 10 Sec  Memory Limit: 128 MBSubmit: 3955  Solved: 2112[Submit][Statu ...

  7. Bzoj 2733: [HNOI2012]永无乡(线段树+启发式合并)

    2733: [HNOI2012]永无乡 Time Limit: 10 Sec Memory Limit: 128 MB Description 永无乡包含 n 座岛,编号从 1 到 n,每座岛都有自己 ...

  8. 线段树合并+并查集 || BZOJ 2733: [HNOI2012]永无乡 || Luogu P3224 [HNOI2012]永无乡

    题面:P3224 [HNOI2012]永无乡 题解: 随便写写 代码: #include<cstdio> #include<cstring> #include<iostr ...

  9. bzoj 2733: [HNOI2012]永无乡

    Description 永无乡包含 n 座岛,编号从 1 到 n,每座岛都有自己的独一无二的重要度,按照重要度可 以将这 n 座岛排名,名次用 1 到 n 来表示.某些岛之间由巨大的桥连接,通过桥可以 ...

  10. bzoj 2733 : [HNOI2012]永无乡 (线段树合并)

    Description 永无乡包含 n 座岛,编号从 1 到 n,每座岛都有自己的独一无二的重要度,按照重要度可 以将这 n 座岛排名,名次用 1 到 n 来表示.某些岛之间由巨大的桥连接,通过桥可以 ...

随机推荐

  1. vSphere存储

    write by xiaoyang 配置iSCSI外部存储 1.      选择配置——硬件——存储 2.      在存储适配器里选择添加软件iSCSI适配器 3.      确认添加 4.     ...

  2. js 用window.open(参数) 打开新窗口,在新窗口怎么获取传过来的参数

    unction openwin(taskno){window.open ('playIt.jsp?taskno='+taskno,'play','height=100,width=400,toolba ...

  3. 爱莲(iLinkIT)的架构与原理

    随着移动互联网时代的到来,手机正在逐步替代其他的设备,手机是电话.手机是即时通讯,手机是相机,手机是导航仪,手机是钱包,手机是音乐播放器……. 除此之外,手机还是一个大大的U盘,曾几何时,我们用一根长 ...

  4. get the runing time of C++ console program.

    // 获取程序运行时间.cpp : 定义控制台应用程序的入口点.// #include "stdafx.h"#include <time.h>#include < ...

  5. opencv获取图片sift特征

    利用opencv2.3来获取图片的sift特征,并输出到标准输出,可用重定向到文件. #include<cstdio> #include"opencv2/opencv.hpp&q ...

  6. mysql颠覆实战笔记(四)--商品系统设计(一):商品主表设计

    版权声明:笔记整理者亡命小卒热爱自由,崇尚分享.但是本笔记源自www.jtthink.com(程序员在囧途)沈逸老师的<web级mysql颠覆实战课程 >.如需转载请尊重老师劳动,保留沈逸 ...

  7. 2.servlet 生命周期

    1.建Web project“2Servlet_Basic” 2.建包com.amaker.servlet 3.建类“ServletBasic.java” package com.amaker.ser ...

  8. Bootstrap Paginator 分页 demo.

    效果如下: 需要的引用以下内容 bootstrap2 http://cnbootstrap.com/ bootstrap-paginator v0.5 主页 http://bootstrappagin ...

  9. C# 汉字转拼音(转)

    (一)将汉字转化成全拼代码: private void button1_Click(object sender, EventArgs e) { this.textBox2.Text = Hz2Py.C ...

  10. IOS_设置启动图片若干问题

    在做项目时, 发现设置了LaunchImage时发现一些问题: 1. 启动图片的设置可以通过两种方法: 1) 通过在LaunchScreen里放入ImageView 并设置图片, 这种方法的好处在于不 ...