采矿(KOP)

金矿的老师傅年底要退休了。经理为了奖赏他的尽职尽责的工作,决定送他一块长方形地。长度为S,宽度为W。老师傅可以自己选择这块地。显然其中包含的采金点越多越好。你的任务就是计算最多能得到多少个采金点。如果一个采金点的位置在长方形的边上,它也应当被计算在内。
任务:
    读入采金点的位置。计算最大的价值。
输入:
    文件KOP.IN的第一行是S和W,(1<=s,w<=10 000);他们分别平行于OX坐标和OY坐标,指明了地域的尺寸。接下来一行是整数n (1<=n<=15 000),表示采金点的总数。然后是n行,每行两个整数,给出了一个采金点的坐标。坐标范围是(-30 000<=x,y<=30 000)。
输出:
    一个整数,最多的采金点数。
样例输入
1 2
12
0 0
1 1
2 2
3 3
4 5
5 5
4 2
1 4
0 5
5 0
2 3
3 2
样例输出
4

果然POI的题目真是经典,在看题解时学到了很多的东西  也是从黑书中寻觅到的

运用到的知识很多,却很清晰

其中一些技巧看似很简单却十分巧妙

这时我才感觉到二叉排序树强大之处

而更详细的题解方法  参见<二分法与统计问题>李睿神牛
#include<cstdio>
#define maxn 15005
#define max(a,b) ((a)>(b)?(a):(b))
int n,m,s,w,num,ans,x[2*maxn],y[2*maxn],yy[2*maxn];
struct {
int y,sum,maxsum;
}t[4*maxn]; void qsX(int,int);
void qsY(int,int);
void buildtree(int);
void ins(int,int,int); int main(){
FILE *in=fopen("kop.in","r");
FILE *out=fopen("kop.out","w");
int i,j,k;
for(i=0;i<=4*maxn-1;i++) t[i].y=-30001;
fscanf(in,"%d%d%d",&s,&w,&n);
for(i=1;i<=n;i++){
fscanf(in,"%d%d",&x[i],&y[i]);
yy[i]=y[i];
yy[n+i]=y[i]+w+1;
}
yy[2*n+1]=-30001;
qsY(1,2*n);
m=0;
for(i=1;i<=2*n;i++)
if(yy[i]!=yy[i+1]) yy[++m]=yy[i];
num=0;
buildtree(1);
qsX(1,n);
i=1;j=1;k=x[j];
while(i<=n&&j<=n){
while(x[i]<=k+s&&i<=n){
ins(1,y[i],1);
ins(1,y[i]+w+1,-1);
i++;
}
if(ans<t[1].maxsum) ans=t[1].maxsum;
while(x[j]==k&&j<=n){
ins(1,y[j],-1);
ins(1,y[j]+w+1,1);
j++;
}
k=x[j];
}
fprintf(out,"%d",ans);
fclose(in);fclose(out);
return 0;
} void qsX(int l,int r){
int i=l,j=r,k=x[(l+r)/2],t;
do{
while(x[i]<k) ++i;
while(x[j]>k) --j;
if(i<=j){
t=x[i];x[i]=x[j];x[j]=t;
t=y[i];y[i]=y[j];y[j]=t;
++i;--j;
}
}while(i<j);
if(i<r) qsX(i,r);
if(j>l) qsX(l,j);
}
void qsY(int l,int r){
int i=l,j=r,k=yy[(l+r)/2],t;
do{
while(yy[i]<k) ++i;
while(yy[j]>k) --j;
if(i<=j){
t=yy[i];yy[i]=yy[j];yy[j]=t;
++i;--j;
}
}while(i<j);
if(i<r) qsY(i,r);
if(j>l) qsY(l,j);
}
void buildtree(int now){
if(2*now<=m) buildtree(2*now);
t[now].y=yy[++num];
t[now].sum=t[now].maxsum=0;
if(2*now+1<=m) buildtree(2*now+1);
}
void ins(int now,int num,int p){
if(num<t[now].y) ins(now*2,num,p);
if(num>t[now].y) ins(now*2+1,num,p);
t[now].sum+=p;
t[now].maxsum=max(t[now*2].maxsum,max(t[now].sum-t[now*2+1].sum,t[now].sum-t[now*2+1].sum+t[now*2+1].maxsum));
}

POI2001 Gold mine(二叉排序树 黑书经典)的更多相关文章

  1. [POI 2001+2014acm上海邀请赛]Gold Mine/Beam Cannon 线段树+扫描线

    Description  Byteman, one of the most deserving employee of The Goldmine of Byteland, is about to re ...

  2. 刘汝佳黑书 pku等oj题目

    原文地址:刘汝佳黑书 pku等oj题目[转]作者:小博博Mr 一.动态规划参考资料:刘汝佳<算法艺术与信息学竞赛><算法导论> 推荐题目:http://acm.pku.edu. ...

  3. HDU3996 Gold Mine(最大权闭合子图)

    #include<cstdio> #include<cstring> #include<queue> #include<algorithm> using ...

  4. POJ 1042 Gone Fishing (贪心)(刘汝佳黑书)

    Gone Fishing Time Limit: 2000MS   Memory Limit: 32768K Total Submissions: 30281   Accepted: 9124 Des ...

  5. PAT1135(红黑书的判定)

    There is a kind of balanced binary search tree named red-black tree in the data structure. It has th ...

  6. 【枚举】【lrj黑书】奇怪的问题(古老的智力题)

    题目描述: 请回答下面的 10 个问题,你的回答应保证每题惟有你的选择是正确的. ⑴ 第一个答案是b 的问题是哪一个?(a )2 ( b ) 3 ( c ) 4 ( d ) 5 ( e ) 6⑵ 恰好 ...

  7. bzoj2539 丘比特的烦恼、黑书P333 (最优二分图匹配)

      丘比特的烦恼 题目描述 Description 随着社会的不断发展,人与人之间的感情越来越功利化.最近,爱神丘比特发现,爱情也已不再是完全纯洁的了.这使得丘比特很是苦恼,他越来越难找到合适的男女, ...

  8. BZOJ1697: [Usaco2007 Feb]Cow Sorting牛排序

    1697: [Usaco2007 Feb]Cow Sorting牛排序 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 387  Solved: 215[S ...

  9. poj 1390 Blocks (经典区间dp 方块消除)

    Blocks Time Limit: 5000MS   Memory Limit: 65536K Total Submissions: 4250   Accepted: 1704 Descriptio ...

随机推荐

  1. api接口通信安全性

    1.采用https协议传输数据 2.白名单.账号密码验证 3.密钥签名token 4.三次握手请求数据前,需要拿到密码才可以请求数据,否则异常

  2. php,javscript调用百地图度API实现标记

    最近一个项目需要用到地图的定位和标记功能,本来考虑使用google map API .但是在国内这个速度确实很慢,有时候加载到一半就出现错了,不过可以通过google agent 来解决在国内的访问速 ...

  3. 3DSoftRenderer

    研究了好几天基本的图形学,对于光栅化的大致过程有点了解了,很感谢网上的很多大牛的无私奉献,我就写一下这几天的总结,希望也能对网络上的知识做出一点点点的贡献. 屏幕有什么特点,无非是一排排的像素点,每个 ...

  4. codeblocks常用快捷键

    CodeBlocks常用操作快捷键编辑部分:Ctrl + A:全选Ctrl + C:复制Ctrl + X: 剪切Ctrl + V:粘贴Ctrl + Z:撤销Ctrl + S:保存Ctrl + Y / ...

  5. html 设置Select options值进行绑定

    <select id="cdms"> <option value="">请选择...</option> <option ...

  6. Linux必学的60个命令

    inux必学的60个命令Linux提供了大量的命令,利用它可以有效地完成大量的工作,如磁盘操作.文件存取.目录操作.进程管理.文件权限设定等.所以,在Linux系统上工作离不开使用系统提供的命令.要想 ...

  7. poj 3522 Slim Span (最小生成树kruskal)

    http://poj.org/problem?id=3522 Slim Span Time Limit: 5000MS   Memory Limit: 65536K Total Submissions ...

  8. E437: terminal capability "cm" required

    执行 vi 的时候出现:E437: terminal capability "cm" required 临时解决: export TERM=xterm

  9. 基于局部敏感哈希的协同过滤算法之simHash算法

    搜集了快一个月的资料,虽然不完全懂,但还是先慢慢写着吧,说不定就有思路了呢. 开源的最大好处是会让作者对脏乱臭的代码有羞耻感. 当一个做推荐系统的部门开始重视[数据清理,数据标柱,效果评测,数据统计, ...

  10. C/C++ 框架,类库,资源集合

    很棒的 C/C++ 框架,类库,资源集合. Awesome C/C++ Standard Libraries Frameworks Artificial Intelligence Asynchrono ...