BZOJ4849[Neerc2016]Mole Tunnels——模拟费用流+树形DP
题目描述
输入
输出
样例输入
0 0 4 1 1
2 4 5 2
样例输出
#include<set>
#include<map>
#include<queue>
#include<cmath>
#include<stack>
#include<cstdio>
#include<vector>
#include<bitset>
#include<cstring>
#include<iostream>
#include<algorithm>
using namespace std;
int f[100010];
int g[100010];
int v[100010][2];
int ans;
int n,m;
int x,mn;
int c[100010];
int main()
{
scanf("%d%d",&n,&m);
for(int i=1;i<=n;i++)
{
scanf("%d",&c[i]);
}
memset(f,0x3f,sizeof(f));
for(int i=n;i>=1;i--)
{
if(c[i])
{
f[i]=0,g[i]=i;
}
if(f[i]+1<f[i>>1])
{
f[i>>1]=f[i]+1,g[i>>1]=g[i];
}
}
for(int j=1;j<=m;j++)
{
scanf("%d",&x);
int pos,anc,sum=0;
mn=1<<30;
for(int i=x;i;i>>=1)
{
if(mn>f[i]+sum)
{
mn=f[i]+sum,pos=g[i],anc=i;
}
sum+=v[i][0]>=0?1:-1;
}
ans+=mn;
c[pos]--;
printf("%d",ans);
if(j!=m)printf(" ");
for(int i=x;i!=anc;i>>=1)
{
v[i][0]<0?v[i][0]++:v[i][1]--;
}
for(int i=pos;i!=anc;i>>=1)
{
v[i][1]<0?v[i][1]++:v[i][0]--;
}
for(int i=x;i!=anc;i>>=1)
{
f[i]=1<<30;
if(c[i]&&f[i]>0)
{
f[i]=0,g[i]=i;
}
if((i<<1)<=n&&f[i<<1]+(v[i<<1][1]>=0?1:-1)<f[i])
{
f[i]=f[i<<1]+(v[i<<1][1]>=0?1:-1),g[i]=g[i<<1];
}
if((i<<1|1)<=n&&f[i<<1|1]+(v[i<<1|1][1]>=0?1:-1)<f[i])
{
f[i]=f[i<<1|1]+(v[i<<1|1][1]>=0?1:-1),g[i]=g[i<<1|1];
}
}
for(int i=pos;i;i>>=1)
{
f[i]=1<<30;
if(c[i]&&f[i]>0)
{
f[i]=0,g[i]=i;
}
if((i<<1)<=n&&f[i<<1]+(v[i<<1][1]>=0?1:-1)<f[i])
{
f[i]=f[i<<1]+(v[i<<1][1]>=0?1:-1),g[i]=g[i<<1];
}
if((i<<1|1)<=n&&f[i<<1|1]+(v[i<<1|1][1]>=0?1:-1)<f[i])
{
f[i]=f[i<<1|1]+(v[i<<1|1][1]>=0?1:-1),g[i]=g[i<<1|1];
}
}
}
}
BZOJ4849[Neerc2016]Mole Tunnels——模拟费用流+树形DP的更多相关文章
- 【BZOJ4849】[Neerc2016]Mole Tunnels 模拟费用流
[BZOJ4849][Neerc2016]Mole Tunnels Description 鼹鼠们在底下开凿了n个洞,由n-1条隧道连接,对于任意的i>1,第i个洞都会和第i/2(取下整)个洞间 ...
- BZOJ 4849 [NEERC2016]Mole Tunnels (模拟费用流)
题目链接 https://www.lydsy.com/JudgeOnline/problem.php?id=4849 题解 其实也是模拟费用流,但是这道题和一般的题目不一样,这道题是在一个完全二叉树上 ...
- [bzoj4849][Neerc2016]Mole Tunnels
来自FallDream的博客,未经允许,请勿转载,谢谢 貌似是省队集训女队讲的题... 今天在bzoj找一道题无果,但是翻到了这道就顺便写了下. 鼹鼠们在底下开凿了n个洞,由n-1条隧道连接,对于任意 ...
- P6122-[NEERC2016]Mole Tunnels【模拟费用流】
正题 题目链接:https://www.luogu.com.cn/problem/P6122 题目大意 给出\(n\)个点的一棵满二叉树,每个点有容量\(c_i\),\(m\)次从\(p_i\)处加一 ...
- 贪心(模拟费用流):NOIP2011 观光公交
[问题描述] 风景迷人的小城Y 市,拥有n 个美丽的景点.由于慕名而来的游客越来越多,Y 市特意安排了一辆观光公交车,为游客提供更便捷的交通服务.观光公交车在第0 分钟出现在1号景点,随后依次前往2. ...
- BZOJ4977[Lydsy1708月赛]跳伞求生——贪心+堆+模拟费用流
题目链接: 跳伞求生 可以将题目转化成数轴上有$n$个人和$m$个房子,坐标分别为$a_{i}$和$b_{i}$,每个人可以进一个他左边的房子,每个房子只能进一个人.每个房子有一个收益$c_{i}$, ...
- 【bzoj1150】[CTSC2007]数据备份Backup 模拟费用流+链表+堆
题目描述 你在一家 IT 公司为大型写字楼或办公楼(offices)的计算机数据做备份.然而数据备份的工作是枯燥乏味的,因此你想设计一个系统让不同的办公楼彼此之间互相备份,而你则坐在家中尽享计算机游戏 ...
- [UOJ455][UER #8]雪灾与外卖——堆+模拟费用流
题目链接: [UOJ455]雪灾与外卖 题目描述:有$n$个送餐员(坐标为$x_{i}$)及$m$个餐厅(坐标为$y_{i}$,权值为$w_{i}$),每个送餐员需要前往一个餐厅,每个餐厅只能容纳$c ...
- 【CF280D】 k-Maximum Subsequence Sum ,线段树模拟费用流
昨天考试被教育了一波.为了学习一下\(T3\)的科技,我就找到了这个远古时期的\(cf\)题(虽然最后\(T3\)还是不会写吧\(QAQ\)) 顾名思义,这个题目其实可以建成一个费用流的模型.我们用流 ...
随机推荐
- Chrome 谷歌浏览器清除HTTPS证书缓存
在地址栏输入 chrome://net-internals/#hsts 找到下图中的输入框,输入对于的域名执行删除就行了
- 我的微软最有价值专家(Microsoft MVP)之路
一.写在前面 2018年对我来说是幸运的一年,对我来说最幸运的事情有两个,一个是在离驾照考试过期还有一个月(报名之后一直没去考)终于拿到了我的驾照,还有一件事莫过于获得了微软MVP.期间,一直有朋友问 ...
- RuntimeError: Model class apps.users.models.User doesn't declare an explicit app_label and isn't in an application in INSTALLED_APPS.
报错代码: File "/home/bsodgm/Desktop/Django_projection/mall/apps/users/views.py", line 9, in & ...
- C#使用OneNote的图片文字识别功能(OCR)
http://www.cnblogs.com/Charltsing/p/OneNoteOCR.html 有需要技术咨询的,联系QQ564955427 前段时间有人问我能不能通过OneNote扫描图片, ...
- jmeter之批量修改请求路径
今天工作时碰到一个问题:测试环境中由于tomcat没指定webapps下的文件夹名,导致tomcat使用了webapps下默认的文件夹名,而我的jmeter脚本都已经做出来了,一共83个接口,挨个改路 ...
- EF内容记录_EF连接Mysql版本问题
EF连接MySQL可用版本,由于EF.MySQLConnection.mysql-for-visualstudio.VS版本.MySQL.Data.MySQL.Data.Entity版本问题较花时间, ...
- 图片转字符画 【学习ing】
1.创建ascii.py 2. 下面是 ascii.py 的完整代码: from PIL import Image import argparse #命令行输入参数处理 parser = argpar ...
- 【Python3练习题 009】 打印出所有的“水仙花数”
# [Python练习题 009] 打印出所有的“水仙花数”,所谓“水仙花数”是指一个三位数,# 其各位数字立方和等于该数本身.例如:153是一个“水仙花数”,# 因为153=1的三次方+5的三次方+ ...
- Jmeter使用笔记之html报告扩展(一)
题记:在用loadrunner的时候可以生成一个HTML的报告,并且里面包含各种图表,各种详细的数据.而在使用Jmeter测试完后并不能直接生成Html 的报告(无论是用GUI还是命令行启动). 经过 ...
- 原生node路由操作以及注意事项
var http = require("http"); var url = require("url"); var ejs = require("ej ...