1218 疫情控制 2012年NOIP全国联赛提高组

时间限制: 2 s

空间限制: 128000 KB

题目等级 : 钻石 Diamond

题目描述 Description

H 国有 n 个城市,这 n 个城市用 n-1 条双向道路相互连通构成一棵树,1 号城市是首都,也是树中的根节点。

H 国的首都爆发了一种危害性极高的传染病。当局为了控制疫情,不让疫情扩散到边境城市(叶子节点所表示的城市),决定动用军队在一些城市建立检查点,使得从首都到边境城市的每一条路径上都至少有一个检查点,边境城市也可以建立检查点。但特别要注意的是,首都是不能建立检查点的。

现在,在 H国的一些城市中已经驻扎有军队,且一个城市可以驻扎多个军队。一支军队可以在有道路连接的城市间移动,并在除首都以外的任意一个城市建立检查点,且只能在一个城市建立检查点。一支军队经过一条道路从一个城市移动到另一个城市所需要的时间等于道路的长度(单位:小时)。

请问最少需要多少个小时才能控制疫情。注意:不同的军队可以同时移动。

输入描述 Input Description

第一行一个整数 n,表示城市个数。

接下来的 n-1 行,每行 3 个整数,u、v、w,每两个整数之间用一个空格隔开,表示从

城市 u 到城市 v 有一条长为 w 的道路。数据保证输入的是一棵树,且根节点编号为 1。

接下来一行一个整数 m,表示军队个数。

接下来一行 m 个整数,每两个整数之间用一个空格隔开,分别表示这 m 个军队所驻扎

的城市的编号。

输出描述 Output Description

共一行,包含一个整数,表示控制疫情所需要的最少时间。如果无法控制疫情则输出-1。

样例输入 Sample Input

4

1 2 1

1 3 2

3 4 3

2

2 2

样例输出 Sample Output

3

数据范围及提示 Data Size & Hint

【输入输出样例说明】

第一支军队在 2 号点设立检查点,第二支军队从 2 号点移动到 3 号点设立检查点,所需时间为 3 个小时。

【数据范围】

保证军队不会驻扎在首都。

对于 20%的数据,2≤ n≤ 10;

对于 40%的数据,2 ≤n≤50,0

/*
这题太好了!!!
二分+lca+贪心策略.
二分[1,∑w].
先dfs序+lca处理出各点关系.
然后二分检验.
贪心策略:
(1)向上走更优.
(2)排序后能最大匹配.
我们先来考虑几种情况
(1)这个军队能够蹦到根节点.
我们处理出蹦到根节点后剩余的时间.
(2)这个军队蹦不到根节点
我们尽量让他往上蹦.
然后向上传标记.
最后只需要扫根节点的儿子就可以了.
*/
#include<iostream>
#include<cstdio>
#include<cstring>
#include<algorithm>
#define MAXN 50001
#define D 20
using namespace std;
int fa[MAXN][D+5],deep[MAXN],son[MAXN],head[MAXN],n,m,dis[MAXN],a[MAXN],tot,ans=1e9,top,cut,sum;
bool b[MAXN];
struct data{int v,u;}s[MAXN],c[MAXN];
struct egde{int v,next,x;}e[MAXN*2];
int read()
{
int x=0,f=1;char ch=getchar();
while(ch<'0'||ch>'9'){if(ch=='-')f=-1;ch=getchar();}
while(ch>='0'&&ch<='9') x=x*10+ch-48,ch=getchar();
return x*f;
}
void add(int u,int v,int z)
{
e[++tot].v=v;
e[tot].x=z;
e[tot].next=head[u];
head[u]=tot;
}
bool cmp(const data &x,const data &y)
{
return x.v<y.v;
}
void dfs(int now,int father,int d)
{
fa[now][0]=father;
for(int i=head[now];i;i=e[i].next)
{
if(father!=e[i].v)
{
dis[e[i].v]=dis[now]+e[i].x;
dfs(e[i].v,now,d+1);
}
}
}
void get_father()
{
for(int j=1;j<=20;j++)
for(int i=1;i<=n;i++)
fa[i][j]=fa[fa[i][j-1]][j-1];
}
void slove(int u,int fa)
{
bool flag=false,p=1;
for(int i=head[u];i;i=e[i].next)
{
int v=e[i].v;
if(fa!=v)
slove(v,u),p&=b[v],flag=true;
}
if(flag&&p&&u!=1) b[u]=true;return ;
}
bool check(int x)
{
memset(b,0,sizeof(b));
int father=0;top=0,cut=0;
for(int i=1;i<=m;i++)
{
int now=a[i],d=0;
if(dis[now]<x)
father=1;
else for(int j=20;j>=0;j--)
{
if(fa[now][j]&&dis[now]-dis[fa[now][j]]<=x)
{
father=fa[now][j];
d=dis[now]-dis[fa[now][j]];
break;
}
}
if(father!=1) b[father]=true;
else
{
s[++top].v=x-dis[now];
for(int j=20;j>=0;j--)
if(fa[now][j]>1)
now=fa[now][j];
s[top].u=now;
}
}
slove(1,0);
for(int i=head[1];i;i=e[i].next)
if(!b[e[i].v])
c[++cut].u=e[i].v,c[cut].v=e[i].x;
sort(s+1,s+top+1,cmp),sort(c+1,c+cut+1,cmp);
int j=1;c[cut+1].v=1e9;
for(int i=1;i<=top;i++)
{
if(!b[s[i].u]) b[s[i].u]=true;
else if(s[i].v>=c[j].v) b[c[j].u]=true;
while(b[c[j].u]) j++;
}
return j>cut;
}
void erfen(int ll,int rr)
{
int mid;
while(ll<=rr)
{
mid=(ll+rr)>>1;
if(check(mid)) ans=mid,rr=mid-1;
else ll=mid+1;
}
}
int main()
{
int x,y,z;
n=read();
for(int i=1;i<n;i++)
{
x=read(),y=read();z=read();
add(x,y,z);sum+=z;add(y,x,z);
}
m=read();
for(int i=1;i<=m;i++)
a[i]=read();
dfs(1,0,0);
get_father();
erfen(1,sum);
if(ans==1e9) printf("-1");
else printf("%d\n",ans);
return 0;
}

Codevs 1218 疫情控制 2012年NOIP全国联赛提高组的更多相关文章

  1. 疫情控制 2012年NOIP全国联赛提高组(二分答案+贪心)

    P1084 疫情控制 题目描述 H 国有 n 个城市,这 n 个城市用 n-1 条双向道路相互连通构成一棵树,1 号城市是首都,也是树中的根节点. H 国的首都爆发了一种危害性极高的传染病.当局为了控 ...

  2. Codevs 1217 借教室 2012年NOIP全国联赛提高组

    1217 借教室 2012年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 在大学期间,经常需要租借教 ...

  3. Codevs 1198 国王游戏 2012年NOIP全国联赛提高组

    1198 国王游戏 2012年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 恰逢 H 国国庆,国王邀 ...

  4. Codevs 1200 同余方程 2012年NOIP全国联赛提高组

    1200 同余方程 2012年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description 求关于 x 同余方程 a ...

  5. 开车旅行 2012年NOIP全国联赛提高组(倍增+set)

    开车旅行 2012年NOIP全国联赛提高组  时间限制: 1 s  空间限制: 128000 KB  题目等级 : 钻石 Diamond     题目描述 Description 小A 和小B决定利用 ...

  6. Codevs 3286 火柴排队 2013年NOIP全国联赛提高组 树状数组,逆序对

    题目:http://codevs.cn/problem/3286/ 3286 火柴排队  2013年NOIP全国联赛提高组  时间限制: 1 s   空间限制: 128000 KB   题目等级 : ...

  7. Codevs 1069 关押罪犯 2010年NOIP全国联赛提高组

    1069 关押罪犯 2010年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 题目描述 Description S 城现有两座监狱,一共 ...

  8. Codevs 3731 寻找道路 2014年 NOIP全国联赛提高组

    3731 寻找道路 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 黄金 Gold 题目描述 Description 在有向图G中,每条边的长度均为1,现给定起点和终点,请你在图中找 ...

  9. Codevs 3287 货车运输 2013年NOIP全国联赛提高组(带权LCA+并查集+最大生成树)

    3287 货车运输 2013年NOIP全国联赛提高组 时间限制: 1 s 空间限制: 128000 KB 题目等级 : 钻石 Diamond 传送门 题目描述 Description A 国有 n 座 ...

随机推荐

  1. Ms SQL Server 约束和规则

    一.SQL约束 约束定义关于列中允许值的规则,是强制完整性的标准机制. 使用约束优先于使用触发器.规则和默认值.查询优化器也使用约束定义生成高性能的查询执行计划. 1:类型 约束的类型一共分三种 域约 ...

  2. 1.(1)编写一个接口ShapePara,要求: 接口中的方法: double getArea():获得图形的面积。double getCircumference():获得图形的周长 (2)编写一个圆类Circle,要求:圆类Circle实现接口ShapePara。 该类包含有成员变量: radius:public 修饰的double类型radius,表示圆的半径。 x:private修饰的dou

    package jiekou1; public interface ShapePara { //定义常量PI final double PI=3.14; //定义抽象方法 //获得图形面积 doubl ...

  3. 【转】Netty那点事(三)Channel中的Pipeline

    [原文]https://github.com/code4craft/netty-learning/blob/master/posts/ch3-pipeline.md Channel是理解和使用Nett ...

  4. Struts中文件的上传与下载

    前面学到的用组件去上传 前台: 1.post表单提交 2.表单类型 multipart/form-data 3.intput type=file 后台: Apach提供的FileUpload组件 核心 ...

  5. JNI-使用RegisterNatives注册本地方法

    转自: http://blog.chinaunix.net/uid-26009923-id-3410141.html 1. 以前在jni中写本地方法时,都会写成 Java_com_example_he ...

  6. 安卓Android控件ListView获取item中EditText值

    可以明确,现在没有直接方法可以获得ListView中每一行EditText的值. 解决方案:重写BaseAdapter,然后自行获取ListView中每行输入的EditText值. 大概算法:重写Ba ...

  7. Oracle DataGuard数据备份方案详解

    Oracle DataGuard是一种数据库级别的HA方案,最主要功能是冗灾.数据保护.故障恢复等. 在生产数据库的"事务一致性"时,使用生产库的物理全备份(或物理COPY)创建备 ...

  8. IIS连接数

    IIS连接数,也叫IIS并发数(Current Connections),是指同一时间内,有多少个对服务器的请求 一般情况下一个浏览器会占用2个IIS连接 同一个浏览器(IE.Firefox等)窗口中 ...

  9. File transfer in android with asmack and Openfire

    http://harryjoy.com/2012/08/18/file-transfer-in-android-with-asmack-and-openfire/ http://www.javacod ...

  10. [React Native] Using the WebView component

    We can access web pages in our React Native application using the WebView component. We will connect ...