bzoj2300
http://www.lydsy.com/JudgeOnline/problem.php?id=2300
终于对了。。。
平衡树又写挂了。。。不要忘记清空原先的root和修改root。。。
#include<bits/stdc++.h>
using namespace std;
const int N = ;
const double eps = 1e-;
struct query {
int x, opt;
} q[N];
struct data {
double x, y; int cut;
} a[N];
int m, Q, len;
double ans[N];
double ans1, n;
namespace splaytree
{
int root;
int child[N][], fa[N];
void zig(int x)
{
int y = fa[x];
fa[x] = fa[y]; child[fa[x]][child[fa[x]][] == y] = x;
child[y][] = child[x][]; fa[child[x][]] = y;
fa[y] = x; child[x][] = y;
}
void zag(int x)
{
int y = fa[x];
fa[x] = fa[y]; child[fa[x]][child[fa[x]][] == y] = x;
child[y][] = child[x][]; fa[child[x][]] = y;
fa[y] = x; child[x][] = y;
}
void splay(int x, int t)
{
while(fa[x] != t)
{
int y = fa[x], z = fa[y];
if(z == t)
{
child[y][] == x ? zig(x) : zag(x); break;
}
// child[y][0] == x ? zig(x) : zag(x);
// child[z][0] == x ? zig(x) : zag(x);
else if(y == child[z][] && x == child[y][]) { zig(y); zig(x); }
else if(y == child[z][] && x == child[y][]) { zag(y); zag(x); }
else if(y == child[z][] && x == child[y][]) { zag(x); zig(x); }
else if(y == child[z][] && x == child[y][]) { zig(x); zag(x); }
}
if(!t) root = x;
}
void add(data t, int k)
{
if(!root) { root = k; return; }
int now = root;
while()
{
if(!child[now][t.x > a[now].x])
{
fa[k] = now; child[now][t.x > a[now].x] = k;
splay(k, ); return;
}
now = child[now][t.x > a[now].x];
}
}
void del(int x)
{
splay(x, );
if(child[x][] * child[x][] == )
{
root = child[x][] + child[x][];
fa[root] = fa[x] = child[x][] = child[x][] = ; return;
}
int now = child[x][];
while(child[now][]) now = child[now][];
fa[child[x][]] = now; child[now][] = child[x][];
root = child[x][]; fa[root] = fa[x] = child[x][] = child[x][] = ;
splay(now, );
}
int Pre(int x)
{
splay(x, );
x = child[x][];
if(!x) return ;
while(child[x][]) x = child[x][];
return x;
}
int Next(int x)
{
splay(x, );
x = child[x][];
if(!x) return ;
while(child[x][]) x = child[x][];
return x;
}
double slope(int x, int y)
{
return (a[y].y - a[x].y) / (a[y].x - a[x].x);
}
double sqr(double x)
{
return x * x;
}
double dis(int x, int y)
{
if(!x || !y) return ;
return sqrt(sqr(a[x].x - a[y].x) + sqr(a[x].y - a[y].y));
}
void insert(data t, int x)
{
add(t, x);
int pre = Pre(x), nxt = Next(x);
ans1 += dis(x, pre) + dis(x, nxt) - dis(nxt, pre);
if(!pre || !nxt) return;
splay(pre, x); splay(nxt, x);
if(slope(pre, x) - slope(x, nxt) <= eps) { ans1 -= dis(x, pre) + dis(x, nxt) - dis(pre, nxt); del(x); return; }
int ppre = Pre(pre), nnxt = Next(nxt);
while(ppre && slope(x, pre) - slope(pre, ppre) >= eps)
{
ans1 -= dis(pre, x) + dis(pre, ppre) - dis(x, ppre);
del(pre); pre = ppre; ppre = Pre(pre);
}
while(nnxt && slope(x, nxt) - slope(nxt, nnxt) <= eps)
{
ans1 -= dis(nxt, x) + dis(nxt, nnxt) - dis(x, nnxt);
del(nxt); nxt = nnxt; nnxt = Next(nxt);
}
}
} using namespace splaytree;
int main()
{
// freopen("defense1.in", "r", stdin);
// freopen("defense.out", "w", stdout);
scanf("%lf%lf%lf%d", &n, &a[].x, &a[].y, &m); m += ;
a[].x = n; a[].y = ;
for(int i = ; i <= m; ++i) scanf("%lf%lf", &a[i].x, &a[i].y);
scanf("%d", &Q);
for(int i = ; i <= Q; ++i)
{
scanf("%d", &q[i].opt);
if(q[i].opt == )
{
scanf("%d", &q[i].x);
a[q[i].x + ].cut = ;
}
}
len = ;
for(int i = ; i <= m; ++i) if(!a[i].cut) insert(a[i], i);
for(int i = Q; i; --i)
if(q[i].opt == ) insert(a[q[i].x + ], q[i].x + );
else if(q[i].opt == ) ans[++len] = ans1;
for(int i = len; i; --i) printf("%.2f\n", ans[i]);
// fclose(stdin); fclose(stdout);
return ;
}
bzoj2300的更多相关文章
- bzoj2300【HAOI2011】防线修建
题目描述 近来A国和B国的矛盾激化,为了预防不测,A国准备修建一条长长的防线,当然修建防线的话,肯定要把需要保护的城市修在防线内部了.可是A国上层现在还犹豫不决,到底该把哪些城市作为保护对象呢?又由于 ...
- 【BZOJ2300】[HAOI2011]防线修建 set维护凸包
[BZOJ2300][HAOI2011]防线修建 Description 近来A国和B国的矛盾激化,为了预防不测,A国准备修建一条长长的防线,当然修建防线的话,肯定要把需要保护的城市修在防线内部了.可 ...
- BZOJ2300: [HAOI2011]防线修建
题目:http://www.lydsy.com/JudgeOnline/problem.php?id=2300 (我只是在发以前写过的题.. 因为题目没说强制在线,所以离线乱搞就可以了.先把点删掉然后 ...
- BZOJ2300[HAOI2011]防线修建——非旋转treap+凸包(平衡树动态维护凸包)
题目描述 近来A国和B国的矛盾激化,为了预防不测,A国准备修建一条长长的防线,当然修建防线的话,肯定要把需要保护的城市修在防线内部了.可是A国上层现在还犹豫不决,到底该把哪些城市作为保护对象呢?又由于 ...
- 2019.02.21 bzoj2300: [HAOI2011]防线修建(set+凸包)
传送门 题意:动态维护凸包周长. 思路: 见这篇求面积的吧反正都是一个套路. 代码: #include<bits/stdc++.h> #define int long long #defi ...
- bzoj2300#2300. [HAOI2011]防线修建
题解:带删点的维护凸包,1.删点2.查询凸包周长 题解:倒着做就成了带加点的维护凸包,加点时维护一下周长就没了 //#pragma GCC optimize(2) //#pragma GCC opti ...
- 【BZOJ2300】【SCOI2011】糖果
差点就忘了还有差分约束这个东西……看见了就要学习一个 原题: 幼儿园里有N个小朋友,lxhgww老师现在想要给这些小朋友们分配糖果,要求每个小朋友都要分到糖果.但是小朋友们也有嫉妒心,总是会提出一些要 ...
- bzoj千题计划236:bzoj2300: [HAOI2011]防线修建
http://www.lydsy.com/JudgeOnline/problem.php?id=2300 维护动态凸包,人懒用的set 用叉积判断,不要用斜率 #include<set> ...
- 【BZOJ2300】【HAOI2011】防线修建
题目大意:给你m+3个点,有q个操作,每次要么询问当前点集构所构成的上凸壳总长度,要么在当前点集中删除一个点. 这题是吼题啊!!! 刚开始想着如何正常地做,考虑过用线段树维护一个区间内的凸包,发现并不 ...
- 【bzoj2300】[HAOI2011]防线修建 离线+STL-set维护凸包
题目描述 给你(0,0).(n,0).(x,y)和另外m个点,除(0,0)(n,0)外每个点横坐标都大于0小于n,纵坐标都大于0. 输入 第一行,三个整数n,x,y分别表示河边城市和首都是(0,0), ...
随机推荐
- Java基础——面向对象(封装——继承——多态 )
对象 对象: 是类的实例(实现世界中 真 实存在的一切事物 可以称为对象) 类: 类是对象的抽象描述 步骤: 1.定义一个类 (用于 描述人:) ( * 人:有特征和行为) 2.根据类 创建对象 -- ...
- Android 项目Log日志输出优化
概述 Android开发过程中经常需要向控制台输出日志信息,有些人还在用Log.i(tag,msg)的形式或者system.out.println(msg)方式吗?本篇文章对日志信息输出进行优化,以达 ...
- (2) GoJS Node简介
node GoJS提供了非常简单的创建Node节点的方法,可将文本内容.结点形状.背景颜色.边距等属性通过数据绑定[go.Binding]直接绑定到对应的Node数据中. 本文简单介绍Node的创建过 ...
- 洛谷——P2047 [NOI2007]社交网络
P2047 [NOI2007]社交网络 $Floyd$,一眼看到就是他(博主是不小心瞄到了这个题的标签吧qwq) 这个题目只要预处理出$S$到$T$的最短路的条数即可,类似$Spfa$的更新方法 如果 ...
- 「 Luogu P2285 」打鼹鼠
解题思路 第一眼看上去觉得要设计一个三维的 DP,$dp[i][j][k]$ 表示在 $(i,j)$ 这个位置上 $k$ 时刻能够打死的最多的鼹鼠. 但是被数据范围卡死.完全开不开数组啊. 然后注意到 ...
- 关于DEV-c++ 运行窗口闪退的解决办法
因为程序默认运行结束自动关闭,所以运行窗口会被秒关,反复下载了很多遍也没有解决. 上网看过许多博客后,有好多方法,总结一下: ①在return 0:前加getchar():(getchar():是得到 ...
- UVA-1572 Self-Assembly(拓扑排序判断有向环)
题目: 给出几种正方形,每种正方形有无穷多个.在连接的时候正方形可以旋转.翻转. 正方形的每条边上都有一个大写英文字母加‘+’或‘-’.00,当字母相同符号不同时,这两条边可以相连接,00不能和任何边 ...
- 一篇入门Express
目录 1.安装 2.Hello World 3.基础路由设置 4.高级路由设置 5.静态文件 6.中间件 7.生成器 1.安装 Express 是一个 基于 Node.js 的简洁灵活的 Web 应用 ...
- Linux mpstat-显示各个可用CPU的状态
更多linux 性能监测与优化 关注:linux命令大全 mpstat命令指令主要用于多CPU环境下,它显示各个可用CPU的状态系你想.这些信息存放在/proc/stat文件中.在多CPUs系统里,其 ...
- 【Codeforces 489D】Unbearable Controversy of Being
[链接] 我是链接,点我呀:) [题意] 让你找到(a,b,c,d)的个数 这4个点之间有4条边有向边 (a,b)(b,c) (a,d)(d,c) 即有两条从a到b的路径,且这两条路径分别经过b和d到 ...