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\)) 顾名思义,这个题目其实可以建成一个费用流的模型.我们用流 ...
随机推荐
- 【教程】switch上的Human Fall Flat如何设置本地双人?
1. 保证两个手柄已插入主机上 2. 进入游戏至游戏开始界面 3. 将主机插入拓展坞,等待电视显示 4. 稍等数秒,电视上会提示使用手柄方式 5. 此时按照多人游戏的手柄操作方法即可
- IDEA报错Error:Module 'shop-common' production: java.lang.IndexOutOfBoundsException
问题描述: 本来项目是正常的,编译.运行.启动都是OK的,但是在一次电脑重启后,出现了以上这个问题:Error:Module 'shop-common' production: java.lang.I ...
- Windows之系统自带截屏快捷键
Windows之系统自带截屏快捷键 现在我们都习惯了使用QQ截屏,但是有时候电脑没有网络,也就意味着无法登陆QQ,在这个时候再有截屏的需求时,我们就束手无策了. 截取全屏 现在我说以个Windows系 ...
- MySQL 优化集锦
case 1: 如果筛选or条件有多个的时候,应该将最好判断的放在最前面,将最不好判断的放在最后面 比如,有一个学生表,想要找出其中年龄是20岁,住址中包含666这个数字的记录.可以下面这两个方案: ...
- js 翻牌活动效果
直接上代码 html: <div class="index_main"> <ul class="index_card"> <li ...
- IdentityServer4【Topic】之保护APIs
Protecting APIs 保护api 默认情况下IdentityServer将access token发布成JWT(json web token)格式的. 现在,每个相关的平台都支持验证JWT令 ...
- jvm 虚拟机内存模型
来源:https://blog.csdn.net/A_zhenzhen/article/details/77917991?locationNum=8&fps=1 https://blog ...
- [转帖]CentOS 6 服务器安全配置指南(通用)
CentOS 6 服务器安全配置指南(通用) http://seanlook.com/2014/09/07/linux-security-general-settings/ 发表于 2014-09- ...
- 模态框 modal data-toggle data-target
模态框 modal data-toggle data-target 1. Data-*属性 模态框(modal) 触发事件(data-toggle) 触发对象data-target(ID 或类) ...
- mysql [assword expired
mysql 5.6 在使用Navicat在其他机器上进行远程登录数据库时 会出现 password expired ,需要重新设置一下密码. SET PASSWORD FOR 'root'@'%' = ...