思路:主席树搞一搞。

#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. PHP函数方法

    补充一个P可以HP的特点函数:动态调用 function t(){ echo "welcome"; } function t2(){ echo "beatch" ...

  2. Error creating bean with name 'transactionManager' defined in ServletContext resource XXX

    spring & hibernate整合时候 ,并且使用hibernate.cfg.xml文件时回报这个错误, 解决办法,在hibernate.cfg.xml中加入 <property ...

  3. vue 和react

    React 和 Vue 有许多相似之处,它们都有: 使用 Virtual DOM 提供了响应式 (Reactive) 和组件化 (Composable) 的视图组件. 将注意力集中保持在核心库,而将其 ...

  4. html跑马灯效果

    实现跑马灯的方法很多,其中最简单的是采用一句Html代码来实现,我们在需要出现跑马灯效果的地方插入“<marquee>滚动的文字</marquee>”语句,它的效果如下所示: ...

  5. jQuery 页面加载初始化

    jQuery 页面加载初始化的方法有3种 ,页面在加载的时候都会执行脚本,应该没什么区别,主要看习惯吧,本人觉得第二种方法最好,比较简洁. 第一种: $(document).ready(functio ...

  6. 2017ACM暑期多校联合训练 - Team 2 1009 HDU 60563 TrickGCD (容斥公式)

    题目链接 Problem Description You are given an array A , and Zhu wants to know there are how many differe ...

  7. C - Contest Setting Gym - 101982C dp 补题

    题目链接:https://vjudge.net/contest/273260#problem/C 学习了一下别人的思路,首先去重,然后离散化. dp数组开二维,每一次更新,状态转移方程,dp[ i ] ...

  8. Java的继承和多态

    看了博客园里面的一个文章,关于java的继承和多态: class A ...{ public String show(D obj)...{ return ("A and D"); ...

  9. ASLR pe 分析

    ASLR 转:http://www.cnblogs.com/dliv3/p/6411814.html 3ks @author:dlive 微软从windows vista/windows server ...

  10. ubuntu之一些安装配置的坑

    前言 本博客记录自己使用ubuntu的一些错误和坑. ubuntu不支持yum下载安装机制 命令 sudo apt install yum 是可以安装yum的,但安装好后执行: $ yum insta ...