洛谷P1084 疫情控制(NOIP2012)(二分答案,贪心,树形DP)
费了几个小时杠掉此题,如果不是那水水的数据的话,跟列队的难度真的是有得一比。。。
话说蒟蒻仔细翻了所有的题解,发现巨佬写的都是倍增,复杂度是\(O(n\log n\log nw)\)的,貌似还不够优秀。
其实我们与其对于每一个点都通过倍增向上找到对应位置,还不如直接从上到下dfs一遍,判断:如果当前点子树内初始位置最浅的军队与当前点距离不超过\(mid\),或者所有子树都被封锁,那么当前点也被封锁。
这样以后再二分,时间复杂度降至\(O(n\log nw)\)。其它部分的思路Dalao们的题解里都讲清楚了,蒟蒻也不多说了qwq
#include<bits/stdc++.h>
#define LL long long
#define RG register
#define R RG int
using namespace std;
const int N=5e4+9,M=1e5+9;
int p,he[N],ne[M],to[M],w[M],top[N],at[N],t[N],mn[N];
LL mid,d[N],dis[N];
bool cov[N],use[N];
inline bool cmp(R x,R y){
return d[x]>d[y];
}
void dp(R x,R f){
top[x]=p;
if(mid<d[x])mid=d[x];//控制二分上界
if(to[he[x]]==f)he[x]=ne[he[x]];//悄悄把反边删掉
for(R i=he[x];i;i=ne[i]){
if(to[ne[i]]==f)ne[i]=ne[ne[i]];
d[to[i]]=d[x]+w[i];
dp(to[i],x);
}
}
void dfs(R x){
if(cov[x]){dis[x]=0;return;}
dis[x]=1ll<<60;
if(!(cov[x]=he[x]))return;//到达叶子节点还没有被封锁
for(R y,i=he[x];i;i=ne[i]){
dfs(y=to[i]);
cov[x]&=cov[y];
dis[x]=min(dis[x],dis[y]+w[i]);
}
if(dis[x]<=mid)cov[x]=1;//子树内军队能够赶到
}
int main(){
R n,m,cnt=0,i,u,v;
cin>>n;
for(i=1;i<n;++i){
cin>>u>>v>>w[++p];w[p+1]=w[p];
ne[p]=he[u];to[he[u]=p]=v;++p;
ne[p]=he[v];to[he[v]=p]=u;
}
for(i=he[1];i;i=ne[i])
d[p=to[i]]=w[i],dp(t[++cnt]=to[i],1);
cin>>m;
if(cnt>m)return cout<<"-1"<<endl,0;//无解
for(i=1;i<=m;++i)cin>>at[i];
sort(t+1,t+cnt+1,cmp);//排序,方便接下来贪心
sort(at+1,at+m+1,cmp);
RG LL l=0,r=mid+d[t[1]];
while(l<r){
mid=(l+r)>>1;
memset(cov,0,n+1);
memset(use,0,n+1);
for(i=1;i<=cnt;++i)mn[t[i]]=0;//清空
for(i=1;d[at[i]]>mid;++i)
cov[at[i]]=1;//到不了根节点,直接留在子树内
for(p=i;i<=m;++i)
if(!mn[top[at[i]]])mn[top[at[i]]]=i;
//每个子树预留一个贡献最小的军队
use[0]=1;u=m+1;
for(i=1;i<=cnt;++i){
dfs(t[i]);
if(cov[t[i]])continue;
if(use[mn[t[i]]]){//预留已用,只好拿其它子树的
for(--u;u>=p&&(d[at[u]]+d[t[i]]>mid||use[u]);--u);
if(u<p)break;
use[u]=1;
}
else use[mn[t[i]]]=1;//预留直接用
}
u>=p?r=mid:l=mid+1;
}
cout<<l<<endl;
return 0;
}
洛谷P1084 疫情控制(NOIP2012)(二分答案,贪心,树形DP)的更多相关文章
- 洛谷P1084 疫情控制 [noip2012] 贪心+树论+二分答案 (还有个小bugQAQ
正解:贪心+倍增+二分答案 解题报告: 正好想做noip的题目然后又想落实学长之前讲的题?于是就找上了这题 其实之前做过,70,然后实在细节太多太复杂就不了了之,现在再看一遍感觉又一脸懵了... 从标 ...
- 2018.09.26洛谷P1084 疫情控制(二分+倍增)
传送门 好题啊. 题目要求的最大值最小,看到这里自然想到要二分答案. 关键在于怎么检验. 显然对于每个点向根走比向叶节点更优. 因此我们二分答案之后,用倍增将每个点都向上跳到跳不动为止. 这时我们ch ...
- 洛谷P3576 [POI2014]MRO-Ant colony [二分答案,树形DP]
题目传送门 MRO-Ant colony 题目描述 The ants are scavenging an abandoned ant hill in search of food. The ant h ...
- 洛谷3933 Chtholly Nota Seniorious 二分答案+贪心
题目链接 题意 给你一个N*M的矩阵 (N,M <=2000) 把他分成两部分 使两部分的极差较大的一个最小 求这个最小值.然后分矩阵的要求是:每个部分内部的方块之间,可以通过上下左右相互到 ...
- [NOIP2012] 提高组 洛谷P1084 疫情控制
题目描述 H 国有 n 个城市,这 n 个城市用 n-1 条双向道路相互连通构成一棵树,1 号城市是首都, 也是树中的根节点. H 国的首都爆发了一种危害性极高的传染病.当局为了控制疫情,不让疫情扩散 ...
- NOIP2012 洛谷P1084 疫情控制
Description: H 国有 n 个城市,这 n 个城市用 n-1 条双向道路相互连通构成一棵树,1 号城市是首都,也是树中的根节点. H 国的首都爆发了一种危害性极高的传染病.当局为了控制疫情 ...
- 洛谷P1084 疫情控制(贪心+倍增)
这个题以前写过一遍,现在再来写,感觉以前感觉特别不好写的细节现在好些多了,还是有进步吧. 这个题的核心思想就是贪心+二分.因为要求最小时间,直接来求问题将会变得十分麻烦,但是如果转换为二分答案来判断可 ...
- 洛谷 P1084 疫情控制 —— 二分+码力
题目:https://www.luogu.org/problemnew/show/P1084 5个月前曾经写过一次,某个上学日的深夜,精疲力竭后只有区区10分,从此没管... #include< ...
- 洛谷P1084 疫情控制
题目 细节比较多的二分+跟LCA倍增差不多的思想 首先有这样一个贪心思路,深度越低的检查点越好,而最长时间和深度具有单调性,即给定时间越长,每个军队能向更浅的地方放置检查点.因此可以考虑二分时间,然后 ...
随机推荐
- Linux安装Apache常见报错(二)
配置Apache提示报错configure error: APR could not be located. Please use the --with-apr option. 解决办法: ./con ...
- JUnit的配置及使用
一.安装插件JUnitGenertor V2.0 File->Setting->Plugins->在搜索框里输入JUintGenerator V2.0 二.导入JUnit相关jar包 ...
- java.util.Collections.copy():列表List浅拷贝
今天同事问我怎样将一个列表(list1)拷贝到另一个列表(list2),然后修改新的列表(list2)不会影响到旧的列表(list1),想了一想,这是深拷贝啊. 可是,除了循环new还有别的办法吗,想 ...
- array_column函数
<?php $arr = [ [ 'id'=>1, 'name'=>'wang', 'age'=>10 ], [ 'id'=>2, 'name'=>'yong', ...
- Azure系列2.1.15 —— SharedAccessBlobPolicy
(小弟自学Azure,文中有不正确之处,请路过各位大神指正.) 网上azure的资料较少,尤其是API,全是英文的,中文资料更是少之又少.这次由于公司项目需要使用Azure,所以对Azure的一些学习 ...
- RPC框架-RMI、RPC和CORBA的区别
关键词:RMI RPC CORBA简 介:本篇文章重点阐述RMI,附带介绍RPC和CORBA Java远程方法调用(Java RMI)是一组实现了远程方法调用(rmi)的API. java RMI是远 ...
- python之路--类与类之间的关系
类和类之间的关系 在我们的世界中事物和事物之间总会有一些联系. 在面向对象中. 类和类之间也可以产生相关的关系 1. 依赖关系 执行某个动作的时候. 需要xxx来帮助你完成这个操作. 此时的关系是最轻 ...
- 转 My97日历控件常用功能记录
My97相信大家都不陌生,应该是我所见过的最强大的一个日历控件了,最近的项目中也比较多地用到了此控件,而且项目中经常会有不同时间范围的需求,在此列出一些比较常用的日期范围格式的设置,尽管在My97的官 ...
- MySQL in型子查询陷阱
现在有两个表,table1和table2,table1有1千万数据(id 主键索引),table2有三条数据(uid字段 3,5,7): select * from table1 where id i ...
- jQuery代码优化的9种方法
前面的话 本文将详细介绍jQuery代码优化的9种方法 用对选择器 在jQuery中,可以用多种选择器,选择同一个网页元素.每种选择器的性能是不一样的,应该了解它们的性能差异 1.最快的选择器:id选 ...