#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. Group By 和Having总结

    1.Group By 概述 “Group By”从字面意义上理解就是根据“By”指定的规则对数据进行分组 所谓的分组就是将一个“数据集”划分成若干个“小区域”,然后针对若干个“小区域”进行数据处理. ...

  2. android 学习 之 布局(上)

    学习安卓布局前,先了解三个属性值: 1.fill_parent: 设置一个构件的布局为fill_parent将强制性地使构件扩展,以填充布局单元内尽可能多的空间 2.match_parent: And ...

  3. 「小程序JAVA实战」小程序的视频点赞功能开发(62)

    转自:https://idig8.com/2018/09/24/xiaochengxujavashizhanxiaochengxudeshipindianzangongnengkaifa61/ 视频点 ...

  4. 你真的了解lambda吗?一文让你明白lambda用法与源码分析

    本文作者: cmlanche 本文链接: http://www.cmlanche.com/2018/07/22/lambda用法与源码分析/ 转载来源:cmlanche.com 用法 示例:最普遍的一 ...

  5. 设置myeclipse文件的打开格式

  6. confd test

    vi /etc/confd/confd.toml backend = "consul"confdir = "/etc/confd"log-level = &qu ...

  7. SpringMvc配置拦截器

    SpringMVC可以通过配置拦截器,进行url过滤等处理. 在spring-mvc.xml的配置文件中,如下示: 其中,在<mvc:interceptors>中可以配置多个拦截器< ...

  8. 数据结构notes

    1. 一份很好的数据结构教程,图文并茂,简明扼要,列出每种结构的定义和优缺点,非常适合初学者 via @ranyif https://www.interviewcake.com/data-struct ...

  9. http://www.atool.org/keytype.php#0-tsina-1-53371-397232819ff9a47a7b7e80a40613cfe1

    http://www.atool.org/keytype.php#0-tsina-1-53371-397232819ff9a47a7b7e80a40613cfe1

  10. plsql导入导出表数据

    导出表结构: Tools(工具)-->Export User Objects(导出用户对象) -->选择要导出的表(包括Sequence等)-->.sql文件,导出的都为sql文件 ...