【LOJ】#2888. 「APIO2015」巴邻旁之桥 Palembang Bridges
题解
发现我们选择一座桥会选择力\(\frac{s + t}{2}\)较近的一座桥
然后我们只需要按照\(s + t\)排序,然后枚举断点,左边取所有s和t的中位数,右边同理
动态求中位数用平衡树维护
代码
#include <bits/stdc++.h>
#define fi first
#define se second
#define pii pair<int,int>
#define space putchar(' ')
#define enter putchar('\n')
#define MAXN 100005
#define mp make_pair
#define pb push_back
//#define ivorysi
using namespace std;
typedef long long int64;
typedef unsigned int u32;
template<class T>
void read(T &res) {
res = 0;T f = 1;char c = getchar();
while(c < '0' || c > '9') {
if(c == '-') f = -1;
c = getchar();
}
while(c >= '0' && c <= '9') {
res = res * 10 + c - '0';
c = getchar();
}
res *= f;
}
template<class T>
void out(T x) {
if(x < 0) {x = -x;putchar('-');}
if(x >= 10) out(x / 10);
putchar('0' + x % 10);
}
struct Seg {
int64 s,t,d;
friend bool operator < (const Seg &a,const Seg &b) {
return a.d < b.d;
}
}seg[MAXN];
u32 Rand() {
static u32 x = 1736382156;
return x += x << 2 | 1;
}
struct Treap_node {
Treap_node *lc,*rc;
int64 sum,val;int siz;
u32 pri;
void update() {
sum = val;siz = 1;
if(lc) {sum += lc->sum;siz += lc->siz;}
if(rc) {sum += rc->sum;siz += rc->siz;}
}
}pool[MAXN * 4],*tail = pool,*rt;
Treap_node* Newnode(int64 v) {
Treap_node *res = tail++;
res->lc = res->rc = NULL;res->sum = res->val = v;
res->siz = 1;res->pri = Rand();
return res;
}
Treap_node* Merge(Treap_node *A,Treap_node *B) {
if(!A) return B;
if(!B) return A;
if(A->pri < B->pri) {
A->rc = Merge(A->rc,B);
A->update();
return A;
}
else {
B->lc = Merge(A,B->lc);
B->update();
return B;
}
}
void Split(Treap_node *u,Treap_node *&L,Treap_node *&R,int64 v,bool on) {
if(!u) {L = R = NULL;return;}
int t;
if(!on) t = u->lc ? u->lc->siz + 1 : 1;
else t = u->val;
if(v >= t) {
L = u;
if(!on) v -= t;
Split(u->rc,L->rc,R,v,on);
L->update();
}
else {
R = u;
Split(u->lc,L,R->lc,v,on);
R->update();
}
}
void Insert(Treap_node *&rt,int64 v) {
Treap_node *L,*R;
Split(rt,L,R,v,1);
rt = Merge(Merge(L,Newnode(v)),R);
}
int64 Calc(Treap_node *&rt) {
int s = rt->siz / 2;
Treap_node *L,*R,*p;
Split(rt,L,R,s,0);
int64 res = R->sum - L->sum;
rt = Merge(L,R);
return res;
}
int64 ans,f[MAXN],b[MAXN];
int K,N,tot;
void Solve() {
read(K);read(N);
char p[4],q[4];int64 s,t;
for(int i = 1 ; i <= N ; ++i) {
scanf("%s",p + 1);read(s);scanf("%s",q + 1);read(t);
if(s > t) swap(s,t);
if(p[1] == q[1]) ans += t - s;
else {
++ans;
seg[++tot] = (Seg){s,t,s + t};
}
}
sort(seg + 1,seg + tot + 1);
f[0] = 0;rt = NULL;
for(int i = 1 ; i <= tot ; ++i) {
Insert(rt,seg[i].s);Insert(rt,seg[i].t);
f[i] = Calc(rt);
}
b[tot + 1] = 0;
tail = pool;rt = NULL;
for(int i = tot ; i >= 1 ; --i) {
Insert(rt,seg[i].s);Insert(rt,seg[i].t);
b[i] = Calc(rt);
}
if(K == 1) {out(f[tot] + ans);enter;}
else {
int64 tmp = f[tot];
for(int i = 0 ; i <= tot ; ++i) tmp = min(tmp,f[i] + b[i + 1]);
out(tmp + ans);enter;
}
}
int main() {
#ifdef ivorysi
freopen("f1.in","r",stdin);
#endif
Solve();
}
【LOJ】#2888. 「APIO2015」巴邻旁之桥 Palembang Bridges的更多相关文章
- 「APIO2015」巴邻旁之桥 Palembang Bridges
贪心 先转化一下题意 首先如果一个人的家和办公室在河同一侧那么建桥的时候不用去考虑它,最终把答案加上即可 在河两侧的家和办公室互换不影响答案,那么可以把这个抽象到一个区间$[l,r]$,距离就是$|l ...
- 【BZOJ4071】【APIO2015】巴邻旁之桥
题意: Description 一条东西走向的穆西河将巴邻旁市一分为二,分割成了区域 A 和区域 B. 每一块区域沿着河岸都建了恰好 1000000001 栋的建筑,每条岸边的建筑都从 0 编号到 1 ...
- 【BZOJ4071】[Apio2015]巴邻旁之桥 Treap
[BZOJ4071][Apio2015]巴邻旁之桥 Description 一条东西走向的穆西河将巴邻旁市一分为二,分割成了区域 A 和区域 B. 每一块区域沿着河岸都建了恰好 1000000001 ...
- 4071: [Apio2015]巴邻旁之桥
Description 一条东西走向的穆西河将巴邻旁市一分为二,分割成了区域 A 和区域 B. 每一块区域沿着河岸都建了恰好 1000000001 栋的建筑,每条岸边的建筑都从 0 编号到 10000 ...
- BZOJ4071 & 洛谷3644 & UOJ112:[APIO2015]巴邻旁之桥——题解
https://www.lydsy.com/JudgeOnline/problem.php?id=4071 https://www.luogu.org/problemnew/show/P3644 ht ...
- [bzoj4071] [Apio2015]巴邻旁之桥
Description 一条东西走向的穆西河将巴邻旁市一分为二,分割成了区域 A 和区域 B. 每一块区域沿着河岸都建了恰好 1000000001 栋的建筑,每条岸边的建筑都从 0 编号到 10000 ...
- [APIO2015]巴邻旁之桥
Bzoj权限题 luogu题面 先去掉同边的 首先k==1,即求一个点j 使\(\sum_{i\in A} |D_i - D_j| + \sum_{i\in B} |D_i - D_j|\)最小 因为 ...
- bzoj 4071: [Apio2015]巴邻旁之桥【splay】
用权值线段树会容易一些并快一些,但是想复健一下splay所以打了splay 然后果然不会打了. 解题思路: 首先把家和办公室在同一侧的提出来直接加进答案里: 对于k=1,直接选所有办公室和家的中位数即 ...
- APIO2015 八邻旁之桥/巴邻旁之桥
题目描述: bz luogu 题解: 贪心+权值线段树. $K=1$的时候,答案为$\sum |x-l| + |x-r|$,所以所有端点排序后取中位数即可. $K=2$的时候,一定是左边的一些走左边的 ...
随机推荐
- [LOJ6436][PKUSC2018]神仙的游戏
loj description 给你一个只有01和?的字符串,问你是否存在一种把?改成01的方案使串存在一个长度为\(1-n\)的\(border\).\(n\le5\times10^5\) sol ...
- fzyzojP3979 -- [校内训练20180914]魔法方阵
原题见CF632F https://blog.csdn.net/Steaunk/article/details/80217764 这个比较神仙了 点边转化, 把max硬生生转化成了路径最大值,再考虑所 ...
- 《剑指offer》— JavaScript(34)第一个只出现一次的字符
第一个只出现一次的字符 题目描述 在一个字符串(1<=字符串长度<=10000,全部由大写字母组成)中找到第一个只出现一次的字符,并返回它的位置. *** 思路 新建一个对象,其中key用 ...
- idea中的pom文件中的jar包下载不了,手动下载jar包的方法
问题描述: 在pom文件中添加依赖的时候,程序怎么着都是下载不了,而且实验了各种方式: IDEA引MAVEN项目jar包依赖导入问题解决 https://www.cnblogs.com/a845701 ...
- java基础知识学习--------之枚举类型(1)
枚举类型的概念: /** * 目的:枚举类型 * @author chenyanlong * 日期:2017/10/22 * 网址:http://blog.csdn.net/sup_heaven/ar ...
- Java基础-处理json字符串解析案例
Java基础-处理json字符串解析案例 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任. 作为一名开发人员,想必大家或多或少都有接触到XML文件,XML全称为“extensible ...
- bzoj千题计划236:bzoj2300: [HAOI2011]防线修建
http://www.lydsy.com/JudgeOnline/problem.php?id=2300 维护动态凸包,人懒用的set 用叉积判断,不要用斜率 #include<set> ...
- .NET面试题系列(九)C# 结构体与类的区别
谈一下什么时候使用结构,什么使用类. 我们知道,结构存储在栈中,而栈有1个特点,就是空间较小,但是访问速度较快,堆空间较大,但是访问速度相对较慢.所以当我们描述1个轻量级对象的时候,可以将其定义为结构 ...
- js拾遗: replace 替换参数
先来看一个简单的例子吧. var str = "123X321".replace("X", "$'"); 替换后的 str 是什么呢?是 & ...
- 第7月第26天 iOS httpserver
1. cocoahttpserver 1)httpserver [httpServer start:&error] 2)HTTPConnection [newConnection start] ...