思路:主席树搞一搞。

#include<bits/stdc++.h>
#define LL long long
#define fi first
#define se second
#define mk make_pair
#define PII pair<int, int>
#define y1 skldjfskldjg
#define y2 skldfjsklejg
using namespace std; const int N = 1e5 + ;
const int inf = 0x3f3f3f3f;
const LL INF = 0x3f3f3f3f3f3f3f3f;
const int mod = ; int hs1[N], hs2[N], mnX[N], mxX[N], mnY[N], mxY[N], tot1, tot2, n;
int root[][N]; struct Point {
int x, y;
Point(int _x = , int _y = ) {
x = _x; y = _y;
}
} a[N]; struct Chairman_tree {
int tot;
struct node {
int sum, l, r;
} a[N * ];
void update(int p, int l, int r, int &x, int y) {
x = ++tot; a[x] = a[y]; a[x].sum++;
if(l == r) return;
int mid = l + r >> ;
if(p <= mid) update(p, l, mid, a[x].l, a[y].l);
else update(p, mid + , r, a[x].r, a[y].r);
}
int query(int L, int R, int l, int r, int x, int y) {
if(L > R) return ;
if(l >= L && r <= R) return a[x].sum - a[y].sum;
int mid = l + r >> , ans = ;
if(L <= mid) ans += query(L, R, l, mid, a[x].l, a[y].l);
if(R > mid) ans += query(L, R, mid + , r, a[x].r, a[y].r);
return ans;
}
} ct[]; int main() {
ct[].tot = ct[].tot = ;
memset(mnX, inf, sizeof(mnX));
memset(mnY, inf, sizeof(mnY));
memset(mxX, , sizeof(mxX));
memset(mxY, , sizeof(mxY));
scanf("%d", &n);
for(int i = ; i <= n; i++) {
scanf("%d%d", &a[i].x, &a[i].y);
hs1[++tot1] = a[i].x;
hs2[++tot2] = a[i].y;
}
sort(hs1 + , hs1 + + tot1);
sort(hs2 + , hs2 + + tot2);
tot1 = unique(hs1 + , hs1 + + tot1) - hs1 - ;
tot2 = unique(hs2 + , hs2 + + tot2) - hs2 - ; for(int i = ; i <= n; i++) {
a[i].x = lower_bound(hs1 + , hs1 + + tot1, a[i].x) - hs1;
a[i].y = lower_bound(hs2 + , hs2 + + tot2, a[i].y) - hs2;
mnX[a[i].x] = min(mnX[a[i].x], a[i].y);
mxX[a[i].x] = max(mxX[a[i].x], a[i].y);
mnY[a[i].y] = min(mnY[a[i].y], a[i].x);
mxY[a[i].y] = max(mxY[a[i].y], a[i].x);
} for(int i = ; i <= tot2; i++) {
ct[].update(mnY[i], , tot1, root[][i], root[][i - ]);
ct[].update(mxY[i], , tot1, root[][i], root[][i - ]);
} LL ans = ; for(int i = ; i <= tot1; i++) {
ans += mxX[i] - mnX[i] + ;
ans -= ct[].query(i + , tot1, , tot1, root[][mxX[i]], root[][mnX[i]-]);
ans -= ct[].query(, i - , , tot1, root[][mxX[i]], root[][mnX[i]-]);
} printf("%lld\n", ans);
return ;
}

bzoj 1818 主席树的更多相关文章

  1. bzoj 1901 主席树+树状数组

    修改+查询第k小值 单纯主席树修改会打乱所有,所以再套一个树状数组维护前缀和使得修改,查询都是log 对了,bzoj上不需要读入组数,蜜汁re.. #include<cstdio> #in ...

  2. BZOJ 2588 主席树

    思路: 主席树 做完BZOJ 3123 觉得这是道水啊-- 然后狂RE 狂MLE 要来数据 忘把deep[1]设成1了----------. 啊wocccccccccccccccc //By Siri ...

  3. BZOJ 4771 主席树+倍增+set

    思路: 因为有深度的限制,并且我们是在线段树上维护权值,所以我们把点按照dep排序,然后一个一个修改...主席树的下标就是dfs序,子树的查询就是区间查询... 但是发现这样怎么去维护LCA呢...因 ...

  4. BZOJ 3674/BZOJ 3673 主席树

    思路: 主席树维护可持久化数组 剩下的就是普通的并查集了- //By SiriusRen #include <cstdio> #include <cstring> #inclu ...

  5. BZOJ 3123 主席树 启发式合并

    思路: 主席树 搞树上的k大 x+y-lca(x,y)-fa(lca(x,y)) 按照size小树往大树上插 启发式合并 n*log^2n的 搞定~ //By SiriusRen #include & ...

  6. BZOJ 4448 主席树+树链剖分(在线)

    为什么题解都是离线的-- (抄都没法抄) 搞一棵主席树 1 操作 新树上的当前节点设成1 2 操作 查max(i-xx-1,0)那棵树上这条路径上有多少个点是1 让你找经过了多少个点 查的时候用dee ...

  7. BZOJ 3524主席树裸题 (雾)

    思路: 按权值建一棵主席树 (但是这好像不是正解 空间复杂度是不对的--.) //By SiriusRen #include <cstdio> #include <cstring&g ...

  8. BZOJ 3524 - 主席树

    传送门 题目分析 标准主席树,按照位置插入每个数,对于询问l, r, 在l-1,r两树上按照线段树搜索次数大于(r - l + 1) / 2的数. code #include<bits/stdc ...

  9. BZOJ 3932 - 主席树

    传送门 题目分析 在只打会主席树模板的情况下做了这道题,也算是深有体会. 首先任务可以差分:一个任务是(s, e, p), 则在s处+1, 在e+1处-1,符合前缀.但是我们要查询指定时间的前k任务之 ...

随机推荐

  1. Linux常用网络工具:hping高级主机扫描

    之前介绍了主机扫描工具fping,可以参考我写的<Linux常用网络工具:fping主机扫描>. hping是一款更高级的主机扫描工具,它支持TCP/IP数据包构造.分析,在某些防火墙配置 ...

  2. Kubernetes 1.5通过Ceph实现有状态容器

    在上一篇博文,我们通过kubernetes的devlopment和service完成了sonarqube的部署.看起来已经可用,但是仍然有一个很大的问题.我们知道,像mysql这种数据库是需要保存数据 ...

  3. 基础知识:BT1120

    今天谈点我所理解的BT1120协议. BT1120是高清晰度电视 (HDTV) 演播室信号数字接口,首先说一下接口标准里面的概念,然后谈谈自己的理解,写这个文章的目的就是解释给自己听的,所以都是一些白 ...

  4. CS48 D BIT

    统计一个点对应的和它严格右下方的点,点对数量.由于数据规模很大,不能直接上二维的前缀和,先排一维序,然后用BIT维护前缀和即可. /** @Date : 2017-09-14 20:17:30 * @ ...

  5. 2017 Multi-University Training Contest - Team 1

    1006(6038) 就是对a,b分别求循环节,先统计一下b中所有长度循环节的出现次数,再对a求循环节时只要满足: a的循环节长度 % b的循环节长度=0,那么这个b的循环节就可以计入答案,尼玛只要是 ...

  6. 【BZOJ】4293: [PA2015]Siano 线段树上二分

    [题意]给定n棵高度初始为0的草,每天每棵草会长高a[i],m次收割,每次在d[i]天将所有>b[i]的草收割到b[i],求每次收割量.n<=500000. [算法]线段树上二分 [题解] ...

  7. 某线下赛AWD

    拿别人比赛的来玩一下,或许这就是菜的力量吧. 0x01 任意文件读取: switch ($row['media_type']) { case 0: // 图片广告 ...... break; case ...

  8. Why does OpenCV use BGR color format ?【转】

    转自:http://www.learnopencv.com/why-does-opencv-use-bgr-color-format/ One of the elements of good desi ...

  9. shell编程===执行shell脚本的四种方法

    使用vim创建一个shell文件,命名 hello.sh #!/bin/bash echo "hello shell !" 在linux中进行加载 chmod +x ./hello ...

  10. 百度地图js lite api 支持点聚合

    百度地图lite api 是专门为h5 绘制海量点设计的,但是偏偏忽略掉了点聚合的需求,所以需要自己动手,做一次二次改造. 我们知道点聚合需要引入开源库: MarkerClusterer:  http ...