「6月雅礼集训 2017 Day2」C
【题目大意】
有一棵n个点的完全二叉树,边权均为1,每个点有小鸟容量c[i]
依次来了m只小鸟,第i只小鸟初始位置在pos[i]上,问来了x只小鸟的时候,怎样安排小鸟的路线可以使得小鸟移动的边权和最小,且每个点的小鸟个数不超过小鸟容量。
n,m<=3*10^5
【题解】
一眼看过去费用流
有两种方法
1. 我们对每次来小鸟都新建二分图,S->小鸟容量剩余的点,小鸟容量不够的点->T,互相连边即可。
复杂度O(n^3 + n * MinCostFlow)
2. 我们对于整棵树建一张图,每次相当于多连了一条边,跑一边spfa增广即可。
复杂度O(n * MinCostFlow)
考场写第一种啊。。qwq
那么考虑第二种,我们模拟spfa的增广过程,显然是选一条最短路来增广。
由于完全二叉树,树高log,我们可以枚举这只小鸟要迁到的点和pos的LCA,然后顺便维护子树内到这个点的最小值即可。
每次选出一条路,就把这条路上模拟退流、流边、流反向边等等操作
然后就能过了,由于完全二叉树,操作都是log的。
总复杂度O(nlogn)
# include <stdio.h>
# include <string.h>
# include <iostream>
# include <algorithm> using namespace std; typedef long long ll;
typedef unsigned long long ull;
typedef long double ld; # define RG register
# define ST static const int M = 3e5 + ;
const int mod = , inf = 1e9; int n, m, d[M], id[M], f[M][], c[M]; # define ls (x<<)
# define rs (x<<|) inline void gs(int x) {
d[x] = inf;
if(c[x]) d[x] = , id[x] = x;
if(ls <= n && d[ls] + (f[ls][] ? - : ) < d[x]) d[x] = d[ls] + (f[ls][] ? - : ), id[x] = id[ls];
if(rs <= n && d[rs] + (f[rs][] ? - : ) < d[x]) d[x] = d[rs] + (f[rs][] ? - : ), id[x] = id[rs];
} int main() {
// freopen("C.in", "r", stdin);
// freopen("C.out", "w", stdout);
cin >> n >> m;
for (int i=; i<=n; ++i) scanf("%d", &c[i]);
for (int i=n; i; --i) gs(i);
ll ans = ;
for (int i=, x; i<=m; ++i) {
scanf("%d", &x);
int cnt = , pmi = inf, pid = ;
for (int par=x; par; par>>=) {
if(d[par] + cnt < pmi) pmi = d[par] + cnt, pid = par;
cnt += (f[par][] ? - : );
}
ans += pmi;
// cout << "pid = " << pid << " pmi = " << pmi << ", id = " << id[pid] << endl;
c[id[pid]] --;
for (int y=id[pid]; y!=pid; y>>=) if(f[y][]) --f[y][]; else ++f[y][];
for (int y=x; y!=pid; y>>=) if(f[y][]) --f[y][]; else ++f[y][];
for (int y=id[pid]; y!=pid; y>>=) gs(y);
for (int y=x; y!=pid; y>>=) gs(y);
for (int y=pid; y; y>>=) gs(y);
printf("%lld\n", ans);
}
return ;
}
「6月雅礼集训 2017 Day2」C的更多相关文章
- 「6月雅礼集训 2017 Day2」B
[题目大意] 求n*n的棋盘,每行每列都有2个黑格子的方案数. n<=10^7 [题解] zzq的做法好神奇啊 行列建点,二分图 左边有i个点,右边有j个点的方案数 f[i,j] 左边有i个点, ...
- 「6月雅礼集训 2017 Day2」A
[题目大意] 给出一棵树,求有多少对点(u,v)满足其路径上不存在两个点a,b满足(a,b)=1 n<=10^5 [题解] 考虑找出所有不符合的点对,共有n*ln(n)对,他们要么是祖先-> ...
- 「6月雅礼集训 2017 Day10」quote
[题目大意] 一个合法的引号序列是空串:如果引号序列合法,那么在两边加上同一个引号也合法:或是把两个合法的引号序列拼起来也是合法的. 求长度为$n$,字符集大小为$k$的合法引号序列的个数.多组数据. ...
- 「6月雅礼集训 2017 Day4」qyh(bzoj2687 交与并)
原题传送门:http://www.lydsy.com/JudgeOnline/problem.php?id=2687 [题目大意] 给出若干区间,求一个区间的大于等于2的子集,使得 |区间并| 和 | ...
- 「6月雅礼集训 2017 Day11」delight
[题目大意] 有$n$天,每天能吃饭.睡觉.什么事也不干 每天吃饭的愉悦值为$e_i$,睡觉的愉悦值为$s_i$,什么都不干愉悦值为0. 要求每连续$k$天都要有至少$E$天吃饭,$S$天睡觉. 求最 ...
- 「6月雅礼集训 2017 Day11」jump
[题目大意] 有$n$个位置,每个位置有一个数$x_i$,代表从$i$经过1步可以到达的点在$[\max(1, i-x_i), \min(i+x_i, n)]$中. 定义$(i,j)$的距离表示从$i ...
- 「6月雅礼集训 2017 Day11」tree
[题目大意] 给出一棵带权树,有两类点,一类黑点,一类白点. 求切断黑点和白点间路径的最小代价. $n \leq 10^5$ [题解] 直接最小割能过..但是树形dp明显更好写 设$f_{x,0/1/ ...
- 「6月雅礼集训 2017 Day10」perm(CodeForces 698F)
[题目大意] 给出一个$n$个数的序列$\{a_n\}$,其中有些地方的数为0,要求你把这个序列填成一个1到$n$的排列,使得: $(a_i, a_j) = 1$,当且仅当$(i, j) = 1$.多 ...
- 「6月雅礼集训 2017 Day8」route
[题目大意] 给出平面上$n$个点,求一条连接$n$个点的不相交的路径,使得转换的方向符合所给长度为$n-2$的字符串. $n \leq 5000$ [题解] 考虑取凸包上一点,然后如果下一个是‘R' ...
随机推荐
- git使用ssh密钥(转)
git使用https协议,每次pull, push都要输入密码,相当的烦.使用git协议,然后使用ssh密钥.这样可以省去每次都输密码. 大概需要三个步骤:一.本地生成密钥对:二.设置github上的 ...
- I两种冒泡算法
两种冒泡算法: 第一个循环,I 定位当前坐标,第二个循环 把 I 之后的每个数都与 I 比较(比 I 小的都去坐标I),第二个循环之后 坐标 I 为数组里最小的数值. 效率比较高的冒泡算法: stat ...
- 【jQuery】 资料
[jQuery] 资料 1. 选择器 http://www.w3school.com.cn/jquery/jquery_ref_selectors.asp 2. 事件 http://www.w3sch ...
- 30分钟 带你浅入seajs源码
上个星期写了浅入requirejs的, 大家都知道 require是AMD规范(Asynchronous Module Definition) 来 今天我们一起看看 CMD规范(Common Mo ...
- Delphi实例之一个简易的浏览器的实现
Delphi实例之一个简易的浏览器的实现 Delphi7的WebBrowser组件提供了很多不错的网页设计的功能,下面做一个简单的浏览器.组件很简单按照下面摆放就行了. 这是运行后的效果 源代码 主页 ...
- php 使用GD库压缩图片,添加文字图片水印
先上一个工具类,提供了压缩,添加文字.图片水印等方法: image.class.php <?php class Image { private $info; private $image; pu ...
- JavaScript中注册时间处理程序的方式
基本的方式有两种: 一.第一种方式,出现在Web初期,给时间目标对象或文档元素设置属性. 1.设置JavaScript对象属性为事件处理程序. 示例: 缺点,这种设计都是围绕着假设每个事件目标对于每种 ...
- ASP.NET程序中设置相对路径的方法
如图所示,这是个绝对路径. 改为相对路径的方法是:AppDomain.CurrentDomain.BaseDirectory. 如下图所示:
- 有关于PHP的基础知识
(1) l 长字符串表示,必须放在“<<<heredoc”和 “heredoc;”之间.主要是<<<,其次是也可以不使用heredoc. l “<< ...
- springboot ueditor 使用心得
1.将ueditor引入项目中会发现,图片不能上传,返回值意思是因配置文件错误,导致图片无法上传 默认情况是使用jsp初始配置文件,这就需要项目支持jsp解析 在maven中引入 <!--添加对 ...