NOIP 2012 疫情控制(二分+贪心+倍增)
题解
二分时间
然后一个显然的事是一个军队向上爬的越高它控制的点越多
所以首先军队尽量往上爬。
当一个军队可以爬到根节点我们记录下它的剩余时间T和它到达根结点时经过的根节点的子节点son。
当一个军队爬不到根节点时我们就让它控制它可以爬到的最高点。
然后我们把爬到根节点的军队按T从小到大排序。
然后按顺序处理
然后假如一个军队没有时间回到它的son,且son还没有控制。就让它控制son。
因为让别的军队去控制它显然更浪费时间。
否则贪心地匹配就好了(尽量小的和小的和匹配)
然后向上爬用倍增来优化。
#include<iostream>
#include<cstring>
#include<cstdio>
#include<algorithm>
#include<cmath>
#include<queue>
using namespace std;
priority_queue<long long,vector<long long>,greater<long long> > q1,q2;
const int N=;
int cnt,head[N],fa[N][],s[N][],top[N],book[N],xb[N],ww[N],www[N],n,m;
long long rest[N];
struct edge{
int nxt,to,w;
}e[];
struct node{
int id,xb;
long long rest;
}k[N];
bool cmp(node a,node b){
return a.rest<b.rest;
}
void add(int u,int v,int w){
cnt++;
e[cnt].nxt=head[u];
e[cnt].to=v;
e[cnt].w=w;
head[u]=cnt;
}
void dfs(int u,int f,int fl){
fa[u][]=f;
s[u][]=fl;
for(int i=;i<=;i++){
fa[u][i]=fa[fa[u][i-]][i-];
s[u][i]=s[fa[u][i-]][i-]+s[u][i-];
}
for(int i=head[u];i;i=e[i].nxt){
int v=e[i].to;
if(v==f)continue;
dfs(v,u,e[i].w);
}
}
void dfs1(int u,int f,int tp){
top[u]=tp;
for(int i=head[u];i;i=e[i].nxt){
int v=e[i].to;
if(v==f)continue;
dfs1(v,u,tp);
}
}
void dfs2(int u,int f){
if(book[u]==)return;
book[u]=;
bool flag=false;
for(int i=head[u];i;i=e[i].nxt){
int v=e[i].to;
if(v==f)continue;
dfs2(v,u);
if(book[v]==)book[u]=;
flag=true;
}
if(!flag)book[u]=;
}
bool pd(long long maxx){
while(!q1.empty())q1.pop();
while(!q2.empty())q2.pop();
for(int i=;i<=n;i++)book[i]=;
for(int i=;i<=m;i++){
k[i].xb=ww[i];
k[i].rest=maxx;
k[i].id=i;
for(int j=;j>=;j--){
if(fa[k[i].xb][j]&&k[i].rest>=s[k[i].xb][j]){
k[i].rest-=s[k[i].xb][j];
k[i].xb=fa[k[i].xb][j];
}
}
}
sort(k+,k++m,cmp);
for(int i=;i<=m;i++){
if(k[i].xb!=)book[k[i].xb]=;
}
dfs2(,);
for(int i=;i<=m;i++){
if(k[i].xb==&&k[i].rest<www[top[ww[k[i].id]]]&&book[top[ww[k[i].id]]]==)book[top[ww[k[i].id]]]=;
else if(k[i].xb==&&(k[i].rest>=www[top[ww[k[i].id]]]||(k[i].rest<www[top[ww[k[i].id]]]&&book[top[ww[k[i].id]]])))q1.push(k[i].rest);
}
if(book[])return true;
for(int i=head[];i;i=e[i].nxt){
if(book[e[i].to]==)q2.push(e[i].w);
}
while(!q2.empty()){
int a=q2.top();
q2.pop();
while(!q1.empty()&&q1.top()<a)q1.pop();
if(q1.empty())return false;
q1.pop();
}
return true;
}
int main(){
scanf("%d",&n);
for(int i=,u,v,w;i<=n-;i++){
scanf("%d%d%d",&u,&v,&w);
add(u,v,w);
add(v,u,w);
}
for(int i=head[];i;i=e[i].nxt){
www[e[i].to]=e[i].w;
dfs1(e[i].to,,e[i].to);
}
dfs(,,);
scanf("%d",&m);
for(int i=;i<=m;i++){
scanf("%d",&ww[i]);
}
long long l=,r=,ans;
while(l<=r){
long long mid=(l+r)>>;
if(pd(mid)){
r=mid-;
ans=mid;
}
else l=mid+;
}
if(r==)printf("-1");
else printf("%lld",ans);
return ;
}
NOIP 2012 疫情控制(二分+贪心+倍增)的更多相关文章
- 【NOIP 2012 疫情控制】***
题目描述 H 国有 n 个城市,这 n 个城市用 n-1 条双向道路相互连通构成一棵树,1 号城市是首都, 也是树中的根节点. H 国的首都爆发了一种危害性极高的传染病.当局为了控制疫情,不让疫情扩散 ...
- 基础算法(二分,贪心):NOIP 2012 疫情控制
题目大意 给出一棵n个节点的树,根是1,要在除根节点以外的点建立检查点,使得从每条根到叶子的路径上都至少存在一个检查点.检查点由军队来建立.初始军队的位置是给定的,移动军队走一条边需要花费这条边的权值 ...
- LUOGU P1084 疫情控制(二分+贪心+树上倍增)
传送门 解题思路 比较神的一道题.首先发现是最小值问题,并且具有单调性,所以要考虑二分答案.其次有一个性质是军队越靠上越优,所以我们要将所有的军队尽量向上提,这一过程我们用倍增实现.发现这时有两种军队 ...
- 洛谷P1084 疫情控制(贪心+倍增)
这个题以前写过一遍,现在再来写,感觉以前感觉特别不好写的细节现在好些多了,还是有进步吧. 这个题的核心思想就是贪心+二分.因为要求最小时间,直接来求问题将会变得十分麻烦,但是如果转换为二分答案来判断可 ...
- noip 2012 疫情控制
/* 考试的时候没想出正解 也没打暴力 时间不够了 随便yy了几种情况按出现的先后顺序处理而没有贪心 的了20分 不粘了 正解是围绕首都的儿子来搞的 显然先二分答案 对于每个限定的最大时间 我们尝试着 ...
- luogu1084 [NOIp2012]疫情控制 (二分答案+倍增+dfs序)
先二分出一个时间,把每个军队倍增往上跳到不能再跳 然后如果它能到1号点,就记下来它跳到1号点后剩余的时间:如果不能,就让它就地扎根,记一记它覆盖了哪些叶节点(我在这里用了dfs序+差分,其实直接dfs ...
- 洛谷P1084 疫情控制 [noip2012] 贪心+树论+二分答案 (还有个小bugQAQ
正解:贪心+倍增+二分答案 解题报告: 正好想做noip的题目然后又想落实学长之前讲的题?于是就找上了这题 其实之前做过,70,然后实在细节太多太复杂就不了了之,现在再看一遍感觉又一脸懵了... 从标 ...
- P1080 【NOIP 2012】 国王游戏[贪心+高精度]
题目来源:洛谷 题目描述 恰逢 H国国庆,国王邀请n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 n 位大臣排成一排,国王 ...
- 【NOIP 2012 国王游戏】 贪心+高精度
题目描述 恰逢 H 国国庆,国王邀请 n 位大臣来玩一个有奖游戏.首先,他让每个大臣在左.右 手上面分别写下一个整数,国王自己也在左.右手上各写一个整数.然后,让这 n 位大臣排 成一排,国王站在队伍 ...
随机推荐
- MYSQL binlog 日志内容查看
记录mysql数据库真正执行更改的所有操作(DML语句),不包含那些没有修改任何数据的语句,不会记录select和show这样的语句. 二进制日志的作用: 1. 可以完成主从复制的功能 2. 进行恢复 ...
- ApacheFlink简介
对无界数据集的连续处理 在我们详细介绍Flink之前,让我们从更高的层面上回顾处理数据时可能遇到的数据集的类型以及您可以选择处理的执行模型的类型.这两个想法经常被混淆,清楚地区分它们是有用的. 首先, ...
- win-visualviewport-space
html.win-hoverable <div class="win-visualviewport-space"></div> <section cl ...
- 关于AJAX异步请求的那些事儿(1)
1.什么事AJAX? Asynchronous Javascript And XML:异步的JS和XML,由Google2002年在GoogleSuggest应用提出,目标实现客户端和服务器“同时”运 ...
- java中三个类别加载器的关系以及各自加载的类的范围
Java在需要使用类别的时候,才会将类别加载,Java的类别载入是由类别载入器(Class loader)来达到的,预设上,在程序启动之后,主要会有三个类别加载器:Bootstrap Loader.E ...
- 初识Git(二)
与我们前一篇随笔一样创建文件夹,init我们创建的文件夹,并且创建一个test.txt文本文件,add文本文件,commit文本文件,接下来在文本文件中添加文本: 与上一次不同的是我们这一次在编辑文件 ...
- 路飞学城Python-Day7
Moudle 2 1.鸡汤中国人均阅读4.35本:日本40本:韩国17本:法国20本:以色列60本成长的路上需要读书,坚持读书内心会得到升华的想法不要太多,尽量多读书,多充电多读书,多看报,少吃零食, ...
- BZOJ 2565 最长双回文串(manacher)
565: 最长双回文串 Time Limit: 10 Sec Memory Limit: 128 MBSubmit: 3343 Solved: 1692[Submit][Status][Discu ...
- C++ STL rope介绍----可持久化平衡树
大致介绍: rope这个东西,我刚刚知道这玩意,用的不是很多,做个简单的介绍. 官方说明:我是刘邦(我估计你是看不懂的). rope就是一个用可持久化平衡树实现的“重型”string(然而它也可以保存 ...
- Tomcat跨域资源共享
1.下载Jar包 cors-filter-1.7.jar java-property-utils-1.9.jar 下载完成后将Jar拷贝到tomcat下lib目录中 2.修改web.xml配置 在29 ...