题解:

判断每一次加进来的时候有几个被破坏,几个添加

然后单调栈维护

代码:

#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的更多相关文章

  1. 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 ...

  2. SPOJ DQUERY D-query(主席树)

    题目 Source http://www.spoj.com/problems/DQUERY/en/ Description Given a sequence of n numbers a1, a2, ...

  3. 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 ...

  4. 【填坑向】spoj COT/bzoj2588 Count on a tree

    这题是学主席树的时候就想写的,,, 但是当时没写(懒) 现在来填坑 = =日常调半天lca(考虑以后背板) 主席树还是蛮好写的,但是代码出现重复,不太好,导致调试的时候心里没底(虽然事实证明主席树部分 ...

  5. SPOJ bsubstr

    题目大意:给你一个长度为n的字符串,求出所有不同长度的字符串出现的最大次数. n<=250000 如:abaaa 输出: 4 2 1 1 1 spoj上的时限卡的太严,必须使用O(N)的算法那才 ...

  6. 【SPOJ 7258】Lexicographical Substring Search

    http://www.spoj.com/problems/SUBLEX/ 好难啊. 建出后缀自动机,然后在后缀自动机的每个状态上记录通过这个状态能走到的不同子串的数量.该状态能走到的所有状态的f值的和 ...

  7. 【SPOJ 1812】Longest Common Substring II

    http://www.spoj.com/problems/LCS2/ 这道题想了好久. 做法是对第一个串建后缀自动机,然后用后面的串去匹配它,并在走过的状态上记录走到这个状态时的最长距离.每匹配完一个 ...

  8. 【SPOJ 8222】Substrings

    http://www.spoj.com/problems/NSUBSTR/ clj课件里的例题 用结构体+指针写完模板后发现要访问所有的节点,改成数组会更方便些..于是改成了数组... 这道题重点是求 ...

  9. SPOJ GSS2 Can you answer these queries II

    Time Limit: 1000MS   Memory Limit: 1572864KB   64bit IO Format: %lld & %llu Description Being a ...

随机推荐

  1. MySQL文档翻译(八)附英文原文---性能优化概览

    优化概述 数据库性能表现依赖于数据库级别的几个因素,比如表,查询和配置设置.这些软件在硬件级别通过CPU和IO操作构筑结果,你需要尽可能的使用最少的资源达到最大的效果.当你专注于数据库的性能表现时,你 ...

  2. 用phantomjs进行web界面自动化测试的几个注意点

    貌似我以前说过不少界面自动化测试的坏话,哈哈.最近接触了phantomjs,发现用它进行web界面测试也挺有意思的,下面举几个我使用过程中发现的注意点. 1.需要指定phantomjs位置,否则使用时 ...

  3. 编程类-----matlab基础语法复习(2)

    2019年美赛准备:matlab基本题目运算 clear,clc %% 计算1/3 + 2/5 + ...3/7 +10/21 % i = 1; j = 3; ans = 0; % while i & ...

  4. 【Django模板006】

    在前面的几节中我们都是用简单的django.HttpResponse来把内容显示到网页上,本节将讲解如何使用渲染模板的方法来显示内容. 1.创建一个zqxt_tmpl项目,和一个名称为learn的应用 ...

  5. android TextView描边

    前言 上一篇已经讲了如何实现textView中粗字体效果,里面主要重写了onDraw方法. 这一边讲一个进阶功能,实现textView的描边效果. 上效果图. 上代码: public class St ...

  6. javascript自定义一个全类型读取的函数

    我爱撸码,撸码使我感到快乐!大家好,我是Counter.因为我们知道,在JavaScript中有自带的方法可以读取类型,但是不很全面,今天来分享下如何自己定义一个函数,将所有传入参数的类型给打印出来, ...

  7. Polly 熔断策略

    熔断策略主要以 CircuitBreaker 来完成. 工作原理 熔断器可以被看作为一个主要含有三个状态的状态机 如果以电路开关来看: 开关闭合对应 CLOSED 状态, 开关打开对应 OPEN 状态 ...

  8. 使用C#创建Windows服务 并发布Windows 服务

    一.开发环境 操作系统:Windows 10 X64 开发环境:VS2015 编程语言:C# .NET版本:.NET Framework 4.0 目标平台:X86 二.创建Windows Servic ...

  9. 处理npm publish报错问题

    上传项目到npm-->为社会做贡献 首先你得有一个项目 npm init 生成package.json 来设置相信息 注册登录npm:npm adduser 输入你的一些信息 查看当前npm登录 ...

  10. 从Scratch到Python:会动的小猫

    大部分人提起儿童编程,就会想到Scratch,然而当儿童升入中学,学习什么语言比较合适呢?我认为,Python是未来的方向,为此我将会把一些经典的Scratch案例用Python重新实现,抛砖引玉,希 ...