hdu 5107 这题说的是给了一个二维的 平面, 平面内有30000个点每个点都有自己的高度,然后又30000次的查询,每次查询给的是(X,Y,K), 要求出set(x,y){x,y|x<=X&&y<=Y } 的所有点,中第K 大的数是多少,存在输出该高度,允许重复; 否者输出-1,。

本来想用主席树做,发现,找前节点还是比较麻烦的。再加上k<=10 还是比较小的, 然后我们按照y设置为线段树的页节点,然后发现每个页节点最多存10种高度,然后他们的父节点只需要合并孩子的两个长度为10的高度数组, 我们将所有的点包括询问的点进行离散化,按x按y从小到大排序, 离散化后查询在数组中, 保证了x一定小于等于当前要插入或者是查询的点,这样就可以减少对于x的处理,然后接下来就是让该点的y找到相应的叶节点,然后用该建筑物的h更新叶节点。 如果是查询就查寻(1,IDX(P[i].y))

#include <algorithm>
#include <cstdio>
#include <string.h>
#include <vector>
using namespace std;
const int maxn=;
typedef int ll;
struct point{
ll x,h[];
}AN;
struct build{
ll x,y,h;
ll id,op;
bool operator < ( const build A ) const {
return x<A.x||(x==A.x&&y<A.y)||(x==A.x&&y==A.y&&op<A.op)||(x==A.x&&y==A.y&&op==A.op&&id<A.id);
}
}P[maxn*];
ll Y[maxn*];
ll ans[maxn];
ll Va,loc,cL,cR,tim;
struct Itree{
point V[maxn**];
void build(int o,int L, int R){
V[o].x=;
if(L==R) return ;
int mid =(L+R)/;
build(o*, L, mid );
build(o*+, mid+, R);
}
void inser(int o ){
int i=;
for( i=; i<V[o].x; i++){
if(Va<V[o].h[i]) break;
}
if(i==) return;
for(int j = V[o].x; j>i; --j)
V[o].h[j]=V[o].h[j-];
V[o].h[i]=Va;
V[o].x=min(V[o].x+,);
}
point maintain( point o1, point o2){
point ans;
int i,j,k;
i=j=k=;
while( (i<o1.x||j<o2.x )&&( k<) ){
if(j>=o2.x ||( i<o1.x && o1.h[i]<o2.h[j] ) )
ans.h[k++] = o1.h[i++];
else ans.h[k++] = o2.h[j++];
}
ans.x=k;
return ans;
}
void update(int o, int L, int R){
if(L==R){
inser(o); return ;
}
int mid = (L+R)>>;
if(loc<=mid) update(o*,L, mid);
else update(o*+,mid+,R);
V[o]=maintain(V[o*], V[o*+]);
}
void query(int o, int L, int R){
if(cL<=L && R<= cR){
if(tim==){
tim=;
AN=V[o];
}else {
AN=maintain(AN,V[o]);
}
return ;
}
int mid = (L+R)>>;
if(cL<=mid) query(o*,L,mid);
if(cR>mid) query(o*+, mid+, R); }
}T;
int main()
{
int n,m;
while(scanf("%d%d",&n,&m)==){
for(int i=; i<n; ++i){
scanf("%d%d%d",&P[i].x,&P[i].y,&P[i].h);
P[i].id=i;
P[i].op=;
Y[i]=P[i].y;
}
for(int i=; i<m; ++i){
scanf("%d%d%d",&P[i+n].x,&P[i+n].y,&P[i+n].h);
P[i+n].id=n+i;
P[i+n].op=;
Y[i+n]=P[i+n].y;
}
sort(Y,Y+n+m);
int Ynum = unique(Y,Y+n+m)-Y;
T.build(,,Ynum);
sort(P,P+n+m);
for(int i=; i<n+m; ++i){
if(P[i].op==){
loc = lower_bound(Y,Y+Ynum,P[i].y)-Y+;
Va= P[i].h;
T.update(, , Ynum);
}else{
tim=;
cR = lower_bound(Y,Y+Ynum,P[i].y)-Y+;
cL=;
T.query(,,Ynum);
if(AN.x>=P[i].h){
ans[P[i].id-n]=AN.h[ P[i].h- ];
} else{
ans[P[i].id-n]=-;
}
}
}
for(int i=; i<m; ++i)
printf("%d\n",ans[i]);
}
return ;
}

hdu5107 线段树的更多相关文章

  1. bzoj3932--可持久化线段树

    题目大意: 最近实验室正在为其管理的超级计算机编制一套任务管理系统,而你被安排完成其中的查询部分.超级计算机中的 任务用三元组(Si,Ei,Pi)描述,(Si,Ei,Pi)表示任务从第Si秒开始,在第 ...

  2. codevs 1082 线段树练习 3(区间维护)

    codevs 1082 线段树练习 3  时间限制: 3 s  空间限制: 128000 KB  题目等级 : 大师 Master 题目描述 Description 给你N个数,有两种操作: 1:给区 ...

  3. codevs 1576 最长上升子序列的线段树优化

    题目:codevs 1576 最长严格上升子序列 链接:http://codevs.cn/problem/1576/ 优化的地方是 1到i-1 中最大的 f[j]值,并且A[j]<A[i] .根 ...

  4. codevs 1080 线段树点修改

    先来介绍一下线段树. 线段树是一个把线段,或者说一个区间储存在二叉树中.如图所示的就是一棵线段树,它维护一个区间的和. 蓝色数字的是线段树的节点在数组中的位置,它表示的区间已经在图上标出,它的值就是这 ...

  5. codevs 1082 线段树区间求和

    codevs 1082 线段树练习3 链接:http://codevs.cn/problem/1082/ sumv是维护求和的线段树,addv是标记这歌节点所在区间还需要加上的值. 我的线段树写法在运 ...

  6. PYOJ 44. 【HNSDFZ2016 #6】可持久化线段树

    #44. [HNSDFZ2016 #6]可持久化线段树 统计 描述 提交 自定义测试 题目描述 现有一序列 AA.您需要写一棵可持久化线段树,以实现如下操作: A v p x:对于版本v的序列,给 A ...

  7. CF719E(线段树+矩阵快速幂)

    题意:给你一个数列a,a[i]表示斐波那契数列的下标为a[i],求区间对应斐波那契数列数字的和,还要求能够维护对区间内所有下标加d的操作 分析:线段树 线段树的每个节点表示(f[i],f[i-1])这 ...

  8. 【BZOJ-3779】重组病毒 LinkCutTree + 线段树 + DFS序

    3779: 重组病毒 Time Limit: 20 Sec  Memory Limit: 512 MBSubmit: 224  Solved: 95[Submit][Status][Discuss] ...

  9. 【BZOJ-3673&3674】可持久化并查集 可持久化线段树 + 并查集

    3673: 可持久化并查集 by zky Time Limit: 5 Sec  Memory Limit: 128 MBSubmit: 1878  Solved: 846[Submit][Status ...

随机推荐

  1. ionic函数 官方使用帮助

    项目里 lib/js/ionic.bundle.js 里很多ionic的函数,里面还带了很多使用示例,认真看一下肯定会对使用ionic有很多帮助啊!! 例如:$http

  2. hive的初步认识与hive的本质

    Hive是什么?就从这儿开始学习.... Hive是建立在Hadoop hdfs上的数据仓库基础架构. Hive可以用来数据抽取转换加载(ETL). Hive定义了简单的类SQL查询语句,称为HQL. ...

  3. JVM优化(一)-- 入门

    一.JVM的概念 JVM是Java Virtual Machine(Java虚拟机)的缩写,JVM是一种用于计算设备的规范,它是一个虚构出来的计算机,是通过在实际的计算机上仿真模拟各种计算机功能来实现 ...

  4. iOS 录音功能的实现

    这两天也调了一下ios的录音,原文链接:http://www.iphoneam.com/blog/index.php?title=using-the-iphone-to-record-audio-a- ...

  5. BNU4207:台风

    东方非想天则(TH12.3)是一款优秀的格斗游戏,其以华丽的弹幕,连贯的技能衔接及优美的音乐吸引了众多玩家(宅男更多-_-),而且各平台上也为其提供了联机的机会. 好了,言归正传,天气系统是本游戏的一 ...

  6. Java虚拟机原理图解

    具体详情参考: http://blog.csdn.net/luanlouis/article/details/41046443 http://blog.csdn.net/luanlouis/artic ...

  7. 由JS函数返回值引发的一场”血案"

    ---恢复内容开始--- 啊...  本来昨天晚上想写来着,结果陪老婆看电视剧就忘了... 呢滴神啊,原谅我吧. 背景:昨天在项目中做一个小功能的时候,出现了个小问题,而且一开始找了半天也没找到原因. ...

  8. Swift - 获取当前系统时间

    // 获取当前系统时间 let date = NSDate() let timeFormatter = NSDateFormatter() timeFormatter.dateFormat = &qu ...

  9. Spring集成Struts、Hibernate----三大框架SSH(Spring、Struts和hibernate)

    Spring 框架可以完成业务层的设计任务,Struts框架可以将表示层和业务层分离,而Hibernate框架可以提供灵活的持久层支持.下面介绍三大框架的集成环境: 1.配置Struts2. I.导入 ...

  10. postgresql----TEMPORARY TABLE和UNLOGGED TABLE

    一.TEMPORARY|TEMP TABLE 会话级或事务级的临时表,临时表在会话结束或事物结束自动删除,任何在临时表上创建的索引也会被自动删除.除非用模式修饰的名字引用,否则现有的同名永久表在临时表 ...