spoj mpoint
题解:
判断每一次加进来的时候有几个被破坏,几个添加
然后单调栈维护
代码:
#include<bits/stdc++.h>
using namespace std;
const int N=;
int n,j,k,ans=,now,oo=;
struct note{int x,y,id;}a[N],b[N];
bool cmp(const note i,const note j){return i.x<j.x;}
struct stack
{
note e[N]; int l,h,t;
void pre(int z){l=;h=t=;e[].x=now;e[].y=oo*z;}
void add(note a,bool z){if ((a.y<e[l].y)^z)e[++l]=a;}
void Xwork(int x,bool z){while (h<=l&&((e[h].x<x)^z))h++;h?h--:;}
void Ywork(int y,bool z){while (t<=l&&((e[t].y<y)^z))t++;}
}c1,c2,c3,c4;
int main()
{
scanf("%d",&n);
for (int i=;i<=n;i++)scanf("%d%d",&a[i].x,&a[i].y),a[i].id=i;
memcpy(b,a,sizeof(b));
std::sort(b+,b+n+,cmp);
for (int i=;i<=n;i++)
{
now=a[i].x;c1.pre(),c2.pre();c3.pre(-),c4.pre(-);
for (k=;k<=n&&b[k].x<a[i].x;k++);
for (j=k-;j;j--)
if (b[j].id<i)
if (b[j].y>a[i].y) c2.add(b[j],);
else c3.add(b[j],);
for (j=k;j<=n;j++)
if (b[j].id<i)
if (b[j].y>a[i].y) c1.add(b[j],);
else c4.add(b[j],);
ans+=c1.l+c2.l+c3.l+c4.l;
for (int j=;j<=c1.l;j++)
{
int x=c1.e[j].x,y=c1.e[j].y,xx,yy;
if (!c3.l) continue;
c2.Ywork(y,);xx=c2.e[c2.t].x;
if (c2.t>c2.l) xx=-oo;c3.Xwork(xx,);
c4.Xwork(x,);yy=c4.e[c4.h].y;c3.Ywork(yy,);
c3.h>c3.l?c3.h--:;c3.t?:c3.t++;
ans-=max(c3.h-c3.t+,);
}
c2.h=c2.t=c3.h=c3.t=c4.h=c4.t=;
for (int j=;j<=c4.l;j++)
{
int x=c4.e[j].x,y=c4.e[j].y,xx,yy;
if (!c2.l) continue;
c3.Ywork(y,);xx=c3.e[c3.t].x;
if (c3.t>c3.l) xx=-oo;c2.Xwork(xx,);
c1.Xwork(x,);yy=c1.e[c1.h].y;c2.Ywork(yy,);
c2.h>c2.l?c2.h--:;c2.t?:c2.t++;ans-=max(c2.h-c2.t+,);
}
printf("%d\n",ans);
}
return ;
}
spoj mpoint的更多相关文章
- BZOJ 2588: Spoj 10628. Count on a tree [树上主席树]
2588: Spoj 10628. Count on a tree Time Limit: 12 Sec Memory Limit: 128 MBSubmit: 5217 Solved: 1233 ...
- SPOJ DQUERY D-query(主席树)
题目 Source http://www.spoj.com/problems/DQUERY/en/ Description Given a sequence of n numbers a1, a2, ...
- SPOJ GSS3 Can you answer these queries III[线段树]
SPOJ - GSS3 Can you answer these queries III Description You are given a sequence A of N (N <= 50 ...
- 【填坑向】spoj COT/bzoj2588 Count on a tree
这题是学主席树的时候就想写的,,, 但是当时没写(懒) 现在来填坑 = =日常调半天lca(考虑以后背板) 主席树还是蛮好写的,但是代码出现重复,不太好,导致调试的时候心里没底(虽然事实证明主席树部分 ...
- SPOJ bsubstr
题目大意:给你一个长度为n的字符串,求出所有不同长度的字符串出现的最大次数. n<=250000 如:abaaa 输出: 4 2 1 1 1 spoj上的时限卡的太严,必须使用O(N)的算法那才 ...
- 【SPOJ 7258】Lexicographical Substring Search
http://www.spoj.com/problems/SUBLEX/ 好难啊. 建出后缀自动机,然后在后缀自动机的每个状态上记录通过这个状态能走到的不同子串的数量.该状态能走到的所有状态的f值的和 ...
- 【SPOJ 1812】Longest Common Substring II
http://www.spoj.com/problems/LCS2/ 这道题想了好久. 做法是对第一个串建后缀自动机,然后用后面的串去匹配它,并在走过的状态上记录走到这个状态时的最长距离.每匹配完一个 ...
- 【SPOJ 8222】Substrings
http://www.spoj.com/problems/NSUBSTR/ clj课件里的例题 用结构体+指针写完模板后发现要访问所有的节点,改成数组会更方便些..于是改成了数组... 这道题重点是求 ...
- SPOJ GSS2 Can you answer these queries II
Time Limit: 1000MS Memory Limit: 1572864KB 64bit IO Format: %lld & %llu Description Being a ...
随机推荐
- python调用远程chromedriver.exe、selenium抓包方法
本地python示例代码: from selenium import webdriver driver = webdriver.Remote(command_executor='http://192. ...
- OpenCV自带dnn的Example研究(1)— classification
这个博客系列,简单来说,今天我们就是要研究 https://docs.opencv.org/master/examples.html下的 6个文件,看看在最新的OpenCV中,它们是如何发挥作用的. ...
- Celery完成定时任务
1.什么是Celery Celery是一个简单.灵活且可靠的,处理大量消息的分布式系统 专注于实时处理的异步任务队列 同时也支持任务调度 celery支持linux,如果windows使用celery ...
- 移动web端在线观看ppt
使用office online 移动端重定向地址,重定向地址生成方式(对ppt地址进行两次编码),代码如下.将代码中http://video.ch9.ms/build/2011/slides/TOOL ...
- Markdown语法进阶
tip:基本都是通过html格式实现的. 插入音频 插入音乐 在网易云音乐里找生成外连接,复制过来就OK了,可惜的是很多都不能生成外联连接.如果想自动播放,可以把auto改成1. 插入视频 直接引用在 ...
- speech
1.李开复:一个人的成功,15%靠专业知识,其余15%人际沟通,公众演讲,以及影响他人的能力 2.演讲是一门遗憾的艺术 3.没有准备就等于准备失败 4.追求完美,就是在追求完蛋 5.宁可千日无机会,不 ...
- Python 使用有道翻译
最近想将一些句子翻译成不同的语言,最开始想使用Python向有道发送请求包的方式进行翻译. 这种翻译方式可行,不过只能翻译默认语言,不能选定语言,于是我研究了一下如何构造请求参数,其中有两个参数最复杂 ...
- Django troubleshootings
当在云服务器上部署Django服务时: 1. 首先要在云上的主机上添加相应的端口访问权限. 2. 在project下面的urls.py里面设置如下: ALLOWED_HOSTS = ['www.aby ...
- springboot2.0配置连接池(hikari、druid)
springboot2.0配置连接池(hikari.druid) 原文链接:https://www.cnblogs.com/blog5277/p/10660689.html 原文作者:博客园--曲高终 ...
- Oracle配置SQL空间操作要点说明
前面配置PL/SQL直接通过SQL查询SDE空间数据库,网上已有诸多示例, 常见问题如下: ORA-06520: PL/SQL: 加载外部库时出错ORA-06522: Unable to load D ...