BZOJ2286: [Sdoi2011]消耗战
建出虚树dp。
把询问点按dfs序排序,用一个以dfs序为关键字的单调栈(以深度为关键字也是一样的),每次将一个询问点与栈顶的点的lca入栈,再将这个询问点入栈,在这个过程中建出一棵树就是虚树。具体看代码。
#include<bits/stdc++.h> #define N 250005 using namespace std; typedef long long LL; int n,m,q; struct edge{ edge* s; int v,w; }e[N<<1],*back=e,*h[N]; void add( int u,int v,int w){ h[u]=&(*back++ =(edge){h[u],v,w}); h[v]=&(*back++ =(edge){h[v],u,w}); } void add(int u,int v){ h[u]=&(*back++ =(edge){h[u],v}); } typedef int ds[N]; ds d,num,p,size,son,top,t,z,v,a; void dfs1(int u){ d[u]=d[p[u]]+1; size[u]=1; int s=0; for(edge* i=h[u];i;i=i->s) if(i->v!=p[u]){ p[i->v]=u; t[i->v]=min(t[u],i->w); dfs1(i->v); size[u]+=size[i->v]; if(s<size[i->v]) s=size[son[u]=i->v]; } } void dfs2(int u){ static int cnt; num[u]=++cnt; if(size[u]!=1){ top[son[u]]=top[u]; dfs2(son[u]); } for(edge*& i=h[u];i;i=i->s) if(i->v!=p[u] &&i->v!=son[u]) dfs2(top[i->v]=i->v); } int lca(int s,int t){ while(top[s]!=top[t]){ if(d[top[s]]<d[top[t]]) swap(s,t); s=p[top[s]]; } return d[s]<d[t]?s:t; } bool foo(int i,int j){ return num[i]<num[j]; } LL dp(int u){ LL s=0; for(edge*& i=h[u];i;i=i->s) s+=dp(i->v); return u==1||s<t[u] &&z[u]!=q+1?s:t[u]; } void writeln(int u){ printf("%d\n",u); } void writeln(LL u){ printf("%lld\n",u); } int main(){ scanf("%d",&n); for(int i=1;i!=n;++i){ int u,v,w; scanf("%d%d%d",&u,&v,&w); add(u,v,w); } t[1]=1e9; dfs1(1); dfs2(top[1]=1); scanf("%d",&q); while(q--){ scanf("%d",&m); for(int j=0;j!=m;++j) scanf("%d",a+j); sort(a,a+m,foo); back=e; int i=v[1]=1,j=0; while(j!=m){ int u=lca(v[i],a[j]); while(d[u]<d[v[i]]){ --i; if(d[u]<d[v[i]]) add(v[i],v[i+1]); else{ add(u,v[i+1]); v[i+=v[i]!=u]=u; } } z[a[j]]=q+1; v[++i]=a[j++]; } while(--i) add(v[i],v[i+1]); writeln(dp(1)); } }
BZOJ2286: [Sdoi2011]消耗战的更多相关文章
- [BZOJ2286][SDOI2011]消耗战(虚树DP)
2286: [Sdoi2011]消耗战 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 4998 Solved: 1867[Submit][Statu ...
- [BZOJ2286][Sdoi2011]消耗战(虚树上DP)
2286: [Sdoi2011]消耗战 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 6457 Solved: 2533[Submit][Statu ...
- bzoj千题计划254:bzoj2286: [Sdoi2011]消耗战
http://www.lydsy.com/JudgeOnline/problem.php?id=2286 虚树上树形DP #include<cmath> #include<cstdi ...
- BZOJ2286 [Sdoi2011]消耗战 【虚树 + 树形Dp】
2286: [Sdoi2011]消耗战 Time Limit: 20 Sec Memory Limit: 512 MB Submit: 4261 Solved: 1552 [Submit][Sta ...
- BZOJ2286 [Sdoi2011]消耗战 和 BZOJ3611 [Heoi2014]大工程
2286: [Sdoi2011]消耗战 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 6371 Solved: 2496[Submit][Statu ...
- [Bzoj2286][Sdoi2011]消耗战(虚树模板题附讲解)
2286: [Sdoi2011]消耗战 Time Limit: 20 Sec Memory Limit: 512 MBSubmit: 4896 Solved: 1824[Submit][Statu ...
- 【学习笔记】虚树复习记(BZOJ2286 SDOI2011 消耗战)
想写战略游戏却想不起来虚树T^T 所以就有了这篇复习记QwQ ——简介!—— 我们在处理树上问题的时候,dfs是一个常用手段,但是我们发现,如果一棵树上只有一部分关键点,每次dfs需要访问好多不是关键 ...
- [bzoj2286][Sdoi2011]消耗战(虚树上的DP)
题目:http://www.lydsy.com:808/JudgeOnline/problem.php?id=2286 分析:对于普通的树形dp:f[x]=min(∑f[son],m[x]),其中f[ ...
- [bzoj2286] [Sdoi2011消耗战
还是虚树恩..模板都能打挂QAQ 先在原树上预处理出mndis[i],表示根节点到节点i 路径上边权的最小值(就是断开i与根的联系的最小花费) 建完虚树在虚树上跑树形DP..f[i]表示断开 i 所 ...
随机推荐
- nios II--实验5——定时器软件部分
软件开发 首先,在硬件工程文件夹里面新建一个software的文件夹用于放置软件部分:打开toolsàNios II 11.0 Software Build Tools for Eclipse,需要进 ...
- ASP.NET MVC 数据库依赖缓存的实现
当数据库中的信息发生变化的时候,应用程序能够获取变化的通知是缓存依赖得以实现的基础.应用程序可以通过轮询获取数据变化的信息,使用轮询的话也不可能重新查一次后再和以前的数据做比较,如果这样的话如果我一个 ...
- 非常实用的jquery版表单验证
<!DOCTYPE html><html> <head> <meta charset="UTF-8"> <script src ...
- html5 播放多个视频。一个接一个的播放
new个video,指定播放列表的第一个视频路径为src.监听end事件,回调里面把video的src改成列表的下一个,再play. 示意代码:var vList = ['视频地址url1', 'ur ...
- (function($, window, document) {}) jQuery 调用解决与其他javascript库冲突的写法
将函数包在红色字体内部,可以解决$符号与其他插件的冲突. <script type="text/javascript"> (function($, window, do ...
- react.js table组件【可以直接使用】
最近在做一个CMS,使用的技术是刚刚学习的react.js,准备制作一个查询的页面以及一个新增的页面. 这是table的公共组件: 我们在使用的过程中,只会用到: 制作出来的查询页面: 新增页面: 上 ...
- mysql-模拟全连接处理
方案:通过union连接查询出所有需要的特殊标签,然后在通过left join与union中的结果集做多表比较. sql select t.`code`,a.`count` as count_a,b. ...
- Js-加密
1.base64加密 在页面中引入base64.js文件,调用方法为: <!DOCTYPE HTML> <html> <head> <meta charset ...
- bash中不可以用字符串做数组下标
bash中可以用字符串做数组下标吗例如 test["abc"]=1------解决方案-------------------- 好像是误会,是awk里可以,bash shell里不 ...
- 升级ubuntu,apt-get update出现Hash Sum mismatch
sudo apt-get update 出现Hash Sum mismatch cd /var/lib/apt sudo rm -fr lists sudo mkdir lists sudo mkdi ...