#include<algorithm>
#include<fstream>
#include<functional>
#include<iostream>
using namespace std;
static const int N=;
typedef long long int64;
struct node
{
int v,w;
node *next;
}alist[*N];
struct heapnode
{
int64 w;
int u;
bool operator>(const heapnode &r)const
{
return w>r.w;
}
};
int p[N][];
int64 w[N][];
void dfs1(int u)
{
for(node *i=alist[u].next;i;i=i->next)
if(i->v!=p[u][])
{
p[i->v][]=u;
w[i->v][]=i->w;
dfs1(i->v);
}
}
bool visit[N];
void dfs2(int u)
{
if(visit[u])return;
if(!alist[u].next->next)return;
visit[u]=true;
for(node *i=alist[u].next;i;i=i->next)
if(i->v!=p[u][])
{
dfs2(i->v);
if(!visit[i->v])
{
visit[u]=false;
break;
}
}
}
int main()
{
ifstream fin("blockade.in");
ofstream fout("blockade.out");
int n(),m();
fin>>n;
node *anode(alist+n+);
for(int i=;i<n-;i++)
{
int u(),v(),ww();
fin>>u>>v>>ww;
anode->v=v;
anode->w=ww;
anode->next=alist[u].next;
alist[u].next=anode++;
anode->v=u;
anode->w=ww;
anode->next=alist[v].next;
alist[v].next=anode++;
}
fin>>m;
static int d[N];
for(int i=;i<m;i++)
fin>>d[i];
int NScount=;
for(node *i=alist[].next;i;i=i->next)
{
NScount++;
p[i->v][]=;
w[i->v][]=i->w;
dfs1(i->v);
}
if(NScount>m)
{
fout<<"-1"<<endl;
return ;
}
for(int j=;j<=;j++)
for(int i=;i<=n;i++)
{
p[i][j]=p[p[i][j-]][j-];
w[i][j]=w[i][j-]+w[p[i][j-]][j-];
}
static heapnode a[N],b[N];
heapnode *atop(),*aback(),*btop(),*bback();
static int _w[N];
for(node *i=alist[].next;i;i=i->next)
_w[i->v]=i->w;
int64 l(),r(1e16),ans(1e16);
greater<heapnode> comp;
while(l<=r)
{
atop=a;
aback=a;
btop=b;
bback=b;
int64 mm=(l+r)>>;
for(int i=;i<=n;i++)
visit[i]=false;
for(int i=;i<m;i++)
{
int u=d[i];
int64 ww=mm;
for(int j=;j>=;j--)
if(p[u][j]&&p[u][j]!=&&ww>=w[u][j])
{
ww-=w[u][j];
u=p[u][j];
}
if(/*p[u][0]==1&&*/ww>w[u][])
{
aback->w=ww-w[u][];
aback->u=u;
aback++;
push_heap(atop,aback,comp);
}
else visit[u]=true;
}
dfs2();
if(visit[])
{
ans=mm;
r=mm-;
}
else
{
for(node *i=alist[].next;i;i=i->next)
if(!visit[i->v])
{
bback->w=i->w;
bback->u=i->v;
bback++;
push_heap(btop,bback,comp);
}
while(btop!=bback||atop!=aback)
{
while(atop!=aback&&!visit[atop->u]&&atop->w<_w[atop->u])
{
visit[atop->u]=true;
pop_heap(atop,aback,comp);
aback--;
}
while(btop!=bback&&visit[btop->u])
{
pop_heap(btop,bback,comp);
bback--;
}
if(btop==bback||atop==aback)break;
if(atop->w>=btop->w)
{
visit[btop->u]=true;
pop_heap(atop,aback,comp);
aback--;
pop_heap(btop,bback,comp);
bback--;
}
else
{
pop_heap(atop,aback,comp);
aback--;
}
}
if(btop==bback)
{
ans=min(ans,mm);
r=mm-;
}
else l=mm+;
}
}
fout<<ans<<endl;
return ;
}

NOIP2015BLOCKADE c++ 代码的更多相关文章

  1. 日期格式代码出现两次的错误 ORA-01810

    错误的原因是使用了两次MM . 一.Oracle中使用to_date()时格式化日期需要注意格式码 如:select to_date('2005-01-01 11:11:21','yyyy-MM-dd ...

  2. 可爱的豆子——使用Beans思想让Python代码更易维护

    title: 可爱的豆子--使用Beans思想让Python代码更易维护 toc: false comments: true date: 2016-06-19 21:43:33 tags: [Pyth ...

  3. iOS代码规范(OC和Swift)

    下面说下iOS的代码规范问题,如果大家觉得还不错,可以直接用到项目中,有不同意见 可以在下面讨论下. 相信很多人工作中最烦的就是代码不规范,命名不规范,曾经见过一个VC里有3个按钮被命名为button ...

  4. Jquery的点击事件,三句代码完成全选事件

    先来看一下Js和Jquery的点击事件 举两个简单的例子 <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN&q ...

  5. redux-amrc:用更少的代码发起异步 action

    很多人说 Redux 代码多,开发效率低.其实 Redux 是可以灵活使用以及拓展的,经过充分定制的 Redux 其实写不了几行代码.今天先介绍一个很好用的 Redux 拓展-- redux-amrc ...

  6. 编写高质量代码:改善Java程序的151个建议(第5章:数组和集合___建议75~78)

    建议75:集合中的元素必须做到compareTo和equals同步 实现了Comparable接口的元素就可以排序,compareTo方法是Comparable接口要求必须实现的,它与equals方法 ...

  7. 使用 .NET WinForm 开发所见即所得的 IDE 开发环境,实现不写代码直接生成应用程序

    直接切入正题,这是我09年到11年左右业余时间编写的项目,最初的想法很简单,做一个能拖拖拽拽就直接生成应用程序的工具,不用写代码,把能想到的业务操作全部封装起来,通过配置的方式把这些业务操作组织起来运 ...

  8. jsp前端实现分页代码

    前端需要订一page类包装,其参数为 private Integer pageSize=10; //每页记录条数=10 private Integer totalCount; //总记录条数 priv ...

  9. 【开源】简单4步搞定QQ登录,无需什么代码功底【无语言界限】

    说17号发超简单的教程就17号,qq核审通过后就封装了这个,现在放出来~~ 这个是我封装的一个开源项目:https://github.com/dunitian/LoTQQLogin ————————— ...

随机推荐

  1. 添加自己的discuz 的积分策略

    在参考了网上的一些文章和discuzx开发手册,开始操作:1.在数据库表pre_common_credit_rule增加一条记录,rulename填“填写推荐人”,action填“txtjr”(跟下面 ...

  2. Maven(五)使用Nexus搭建Maven私服

    文章装载于:http://blog.csdn.net/jun55xiu/article/details/39497089 Nexus介绍 Nexus是Maven仓库管理器,如果你使用Maven,你可以 ...

  3. 【转】楼天城楼教主的acm心路历程(作为励志用)

    利用假期空闲之时,将这几年GCJ,ACM,TopCoder 参加的一些重要比赛作个回顾.昨天是GCJ2006 的回忆,今天时间上更早一些吧,我现在还清晰记得3 年前,我刚刚参加ACM 时参加北京赛区2 ...

  4. Kubernetes集群向指定节点上创建容器

    如果需要限制Pod到指定的Node上运行,则可以给Node打标签并给Pod配置NodeSelector. 给节点添加标签 首先查看节点信息 [root@k8s-master ~]# kubectl g ...

  5. Linux Terminator

    NAME Terminator - Multiple GNOME terminals in one window SYNOPSIS terminator [options] DESCRIPTION T ...

  6. Efficient algorithms for polyploid haplotype phasing 多倍体单体型分型的有效算法

    背景:单倍型的推断,或沿着相同染色体的等位基因序列,是遗传学中的基本问题,并且是许多分析的关键组分,包括混合物图谱,通过下降和插补识别身份区域. 基于测序读数的单倍型定相引起了很多关注. 已经广泛研究 ...

  7. msdn 硬盘

    https://msdn.microsoft.com/library/windows/hardware/ff566204 Returns the ATA-2 identify data, the Se ...

  8. innobackupex工作原理

    写篇文章凑个数,基本是翻译,建议看原文. http://www.percona.com/doc/percona-xtrabackup/2.1/innobackupex/how_innobackupex ...

  9. vue生命周期小笔记

    一张图谨记vue每个生命周期的获取状态 beforecreate :可以在这加个loading事件 created :在这结束loading,还做一些初始化,实现函数自执行 mounted : 在这发 ...

  10. 视觉SLAM的数学基础 第一篇 3D空间的位置表示

    视觉SLAM中的数学基础 第一篇 3D空间的位置表示 前言 转眼间一个学期又将过去,距离我上次写<一起做RGBD SLAM>已经半年之久.<一起做>系列反响很不错,主要由于它为 ...