显然转化为求不包含关键点的矩形个数。考虑暴力,枚举矩形下边界,求出该行每个位置对应的最低障碍点高度,对其建笛卡尔树,答案即为Σhi*(slson+1)*(srson+1),即考虑跨过该位置的矩形个数。

  笛卡尔树就是treap,于是考虑利用treap将其动态维护,将hi设为treap的优先级。移动下边界,可以发现每次相当于将所有点的优先级+1,并对该行出现的关键点将对应位置的优先级设为0,打打标记瞎维护下即可。由于数据随机复杂度很对。

  1. #include<iostream>
  2. #include<cstdio>
  3. #include<cmath>
  4. #include<cstdlib>
  5. #include<cstring>
  6. #include<algorithm>
  7. using namespace std;
  8. #define ll long long
  9. #define N 100010
  10. #define lson tree[k].ch[0]
  11. #define rson tree[k].ch[1]
  12. char getc(){char c=getchar();while ((c<'A'||c>'Z')&&(c<'a'||c>'z')&&(c<'0'||c>'9')) c=getchar();return c;}
  13. int gcd(int n,int m){return m==0?n:gcd(m,n%m);}
  14. int read()
  15. {
  16. int x=0,f=1;char c=getchar();
  17. while (c<'0'||c>'9') {if (c=='-') f=-1;c=getchar();}
  18. while (c>='0'&&c<='9') x=(x<<1)+(x<<3)+(c^48),c=getchar();
  19. return x*f;
  20. }
  21. int n,r,c,root,cnt;
  22. ll ans;
  23. struct data
  24. {
  25. int x,y;
  26. bool operator <(const data&a) const
  27. {
  28. return x<a.x;
  29. }
  30. }a[N];
  31. struct data2{int ch[2],x,p,s,lazy;ll ans;
  32. }tree[N<<1];
  33. void up(int k)
  34. {
  35. tree[k].s=tree[lson].s+tree[rson].s+1;
  36. tree[k].ans=tree[lson].ans+tree[rson].ans+1ll*tree[k].p*(tree[lson].s+1)*(tree[rson].s+1);
  37. }
  38. void move(int &k,int p)
  39. {
  40. int t=tree[k].ch[p];
  41. tree[k].ch[p]=tree[t].ch[!p],tree[t].ch[!p]=k,up(k),up(t),k=t;
  42. }
  43. void build(int &k,int l,int r)
  44. {
  45. if (l>r) return;
  46. k=++cnt;
  47. int mid=l+r>>1;
  48. tree[k].x=mid,tree[k].p=0;
  49. build(lson,l,mid-1);
  50. build(rson,mid+1,r);
  51. up(k);
  52. }
  53. void update(int k,int x)
  54. {
  55. tree[k].lazy+=x;
  56. tree[k].p+=x;
  57. tree[k].ans+=1ll*x*tree[k].s*(tree[k].s+1)/2;
  58. }
  59. void down(int k)
  60. {
  61. update(lson,tree[k].lazy);
  62. update(rson,tree[k].lazy);
  63. tree[k].lazy=0;
  64. }
  65. void modify(int &k,int x)
  66. {
  67. down(k);
  68. if (tree[k].x==x) tree[k].p=0;
  69. else if (tree[k].x<x) modify(rson,x),move(k,1);
  70. else modify(lson,x),move(k,0);
  71. up(k);
  72. }
  73. int main()
  74. {
  75. #ifndef ONLINE_JUDGE
  76. freopen("bzoj2658.in","r",stdin);
  77. freopen("bzoj2658.out","w",stdout);
  78. const char LL[]="%I64d\n";
  79. #else
  80. const char LL[]="%lld\n";
  81. #endif
  82. r=read(),c=read(),n=read();
  83. for (int i=1;i<=n;i++) a[i].x=read(),a[i].y=read();
  84. ans=1ll*r*(r+1)*c*(c+1)/4;
  85. sort(a+1,a+n+1);
  86. build(root,1,c);
  87. int x=0;
  88. for (int i=1;i<=r;i++)
  89. {
  90. update(root,1);
  91. while (a[x+1].x==i)
  92. {
  93. x++;
  94. modify(root,a[x].y);
  95. }
  96. ans-=tree[root].ans;
  97. }
  98. cout<<ans;
  99. return 0;
  100. }
  101. //ans=Σpi*(sl+1)*(sr+1)

  

BZOJ2658 ZJOI2012 小蓝的好友(treap)的更多相关文章

  1. bzoj2658: [Zjoi2012]小蓝的好友(mrx)

    太神辣 treap的随机键值竟然能派上用场.. 要用不旋转的treap来进行维护区间信息 #include<cstdio> #include<cstring> #include ...

  2. 【BZOJ2658】[Zjoi2012]小蓝的好友(mrx) 平衡树维护笛卡尔树+扫描线

    [BZOJ2658][Zjoi2012]小蓝的好友(mrx) Description 终于到达了这次选拔赛的最后一题,想必你已经厌倦了小蓝和小白的故事,为了回馈各位比赛选手,此题的主角是贯穿这次比赛的 ...

  3. 洛谷 P2611 [ZJOI2012]小蓝的好友 解题报告

    P2611 [ZJOI2012]小蓝的好友 题目描述 终于到达了这次选拔赛的最后一题,想必你已经厌倦了小蓝和小白的故事,为了回馈各位比赛选手,此题的主角是贯穿这次比赛的关键人物--小蓝的好友. 在帮小 ...

  4. 【BZOJ2658】[Zjoi2012]小蓝的好友(mrx) (扫描线,平衡树,模拟)

    题面 终于到达了这次选拔赛的最后一题,想必你已经厌倦了小蓝和小白的故事,为了回馈各位比赛选手,此题的主角是贯穿这次比赛的关键人物--小蓝的好友. 在帮小蓝确定了旅游路线后,小蓝的好友也不会浪费这个难得 ...

  5. @bzoj - 2658@ [Zjoi2012]小蓝的好友(mrx)

    目录 @description@ @solution@ @accepted code@ @details@ @description@ 终于到达了这次选拔赛的最后一题,想必你已经厌倦了小蓝和小白的故事 ...

  6. [ZJOI2012]小蓝的好友

    https://www.luogu.org/problemnew/show/P2611 题解 \(n\times m\)肯定过不去.. 我们把给定的点看做障碍点,考虑先补集转化为求全空矩阵. 然后我们 ...

  7. P2611-[ZJOI2012]小蓝的好友【Treap,扫描线】

    正题 题目链接:https://www.luogu.com.cn/problem/P2611 题目大意 \(r*c\)的网格上有\(n\)个标记点,然后求有多少个矩形包含至少一个标记点. \(1\le ...

  8. BZOJ 2658 小蓝的好友

    题目链接:http://www.lydsy.com:808/JudgeOnline/problem.php?id=2658 题意:给出一个n*m的格子.某些格子中有障碍.求包含至少一个障碍的矩形有多少 ...

  9. bzoj AC倒序

    Search GO 说明:输入题号直接进入相应题目,如需搜索含数字的题目,请在关键词前加单引号 Problem ID Title Source AC Submit Y 1000 A+B Problem ...

随机推荐

  1. 快看Sample代码,速学Swift语言(3)-运算符

    运算符是用来检查,更改或组合值的特殊符号或短语.Swift提供的很多常规的运算符,如+.-.*./.%.=.==等,以及逻辑运算的&&.||等等,基本上不需要重复介绍,我们在这里只需要 ...

  2. IDEA+Maven+Tomcat构建项目流程

    0.准备 本文主要解决在IDEA上开发Maven-webapp项目关联Tomcat的问题. 首先,确保本地计算机下载解压了Tomcat压缩包,以及配置好了Java环境. 1.新建Mavne项目 2.I ...

  3. git revert 还有这个坑?

    最近也是终于开启了代码编写之旅,我只能默默地说一句,写代码的感觉,简直不能再爽! 不过也由于 git 的分支管理蛋疼懵逼很久,所以必须记录以及和大家分享一下本次坑爹的旅行. 写在前面 每个公司相比都有 ...

  4. Arduino Core For ESP8266

    如果选择纯C作为ESP8266的开发,有两个途径: 使用乐鑫官方原生的 RTOS-SDK或者NONOS-SDK 使用Arduino IDE 使用PlatformIO 作为一个"Arduino ...

  5. MVC5+EF6 --自定义控制Action访问权限

    本章主要讲解在MVC中灵活控制Action的访问权限: 本章所使用的示例表也是上一张所使用的TbUser.TbRole.TbUserRole: 最终的效果是针对任意一个Action或Controlle ...

  6. Cat8 八类网线是什么?与Cat5、Cat6、Cat7网线的区别?

    若您身处于网络通信行业,相信您应该了解一些以太网线缆,比如说超五类网线.六类网线和七类网线等等.但是您知道Cat8 八类网线 是什么吗?它与五类网线.六类/超六类网线及七类/超七类网线有着怎么样的区别 ...

  7. c++入门之命名空间存在的意义

    看过鸡啄米的C++编程入门系列教程的朋友,应该能注意到,在其中的很多实例中,都有这么一条语句:using namespace std;,即使用命名空间std,其作用就是规定该文件中使用的标准库函数都是 ...

  8. 【转】给word中的代码着色

    基本操作 1)用Notepad++直接编辑代码文件,注意文件后缀,比如.cpp是C++程序,.m是Matlab,linux文件是.sh,写对后缀表示的文件类型,才有对应的语法高亮效果. 2)选中需要的 ...

  9. Jmeter之发送请求入参必须使用编码格式、Jmeter之发送Delete请求可能入参需要使用编码格式

    这里的其中一个属性值必须要先编码再传参才可以,具体可以通过抓包分析观察:

  10. echarts使用笔记四:双Y轴

    1.双Y轴显示数量和占比 app.title = '坐标轴刻度与标签对齐'; option = { title : { //标题 x : 'center', y : 5, text : '数量和占比图 ...