#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. 搜索框请输入关键字 onfocus 和 onblur

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  2. IE浏览器中不支持cookie问题

    /** * Cookie plugin * * Copyright (c) 2006 Klaus Hartl (stilbuero.de) * Dual licensed under the MIT ...

  3. zk分布式锁-排它锁简单实现

    package Lock; import java.util.concurrent.CountDownLatch;import java.util.concurrent.TimeUnit;import ...

  4. UGUI 锚点设置为四方扩充模式然后设置局部坐标为0将出现什么问题

    UGUI 锚点设置为四方扩充模式然后设置局部坐标为0将出现什么问题? 情形:按钮A挂在主画布上.四方扩充模式.A的中心和画面中心不重合. 这时候用代码设置A.localPosition = new V ...

  5. springboot+shiro+jwt

    1.添加依赖 <dependency> <groupId>org.apache.shiro</groupId> <artifactId>shiro-sp ...

  6. How To Use Google Flags

    [How To Use Google Flags] 1.Commandline flags are flags that users specify on the command line when ...

  7. leetcode 235 236 二叉树两个节点的最近公共祖先

    描述: 给定二叉树两个节点,求其最近公共祖先.最近即所有公共祖先中深度最深的. ps:自身也算自身的祖先. 235题解决: 这是二叉搜索树,有序的,左边小右边大. TreeNode* lowestCo ...

  8. IDEA07 快捷键统计插件之Key Promoter X

    1 官方介绍 该插件会统计你鼠标操作的次数,然后在一个窗口中展示出来 https://plugins.jetbrains.com/plugin/9792-key-promoter-x 2 下载.安装. ...

  9. java高级工程师(三)

    一.独白 之前也面试别人,现在轮到自己找工作,怎么说呢,每个面试官的看法不一样,面试的方式就不一样,比如我面试别人我喜欢问项目中他用到了那些,然后针对用到的技术去问一些问题,或者说对于某些场景的一些技 ...

  10. CentOS 6.5网络配置静态IP地址

    打开VMvare,并进入虚拟机 2 输入用户名,按回车键,再输入密码,登录系统 3 进行网络配置前,需要确认几个事情: 1. 网络适配器模式是否为NAT模式 右键虚拟机,或者点击VMvare菜单栏中的 ...