BZOJ 2286: [Sdoi2011]消耗战
2286: [Sdoi2011消耗战
Time Limit: 20 Sec Memory Limit: 512 MB
Submit: 2082 Solved: 736
[Submit][Status][Discuss]
Description
Input
第一行一个整数n,代表岛屿数量。
接下来n-1行,每行三个整数u,v,w,代表u号岛屿和v号岛屿由一条代价为c的桥梁直接相连,保证1<=u,v<=n且1<=c<=100000。
第n+1行,一个整数m,代表敌方机器能使用的次数。
接下来m行,每行一个整数ki,代表第i次后,有ki个岛屿资源丰富,接下来k个整数h1,h2,…hk,表示资源丰富岛屿的编号。
Output
输出有m行,分别代表每次任务的最小代价。
Sample Input
1 5 13
1 9 6
2 1 19
2 4 8
2 3 91
5 6 8
7 5 4
7 8 31
10 7 9
3
2 10 6
4 5 7 8 3
3 9 4 6
Sample Output
32
22
HINT
对于100%的数据,2<=n<=250000,m>=1,sigma(ki)<=500000,1<=ki<=n-1
Source
虚树入门题,如果你想知道虚树如何构造:http://user.qzone.qq.com/872191552/main
DP
记dis[i]为点i到根节点的路径中最小的边的权值
f[i]=min(dis[i],sigma f[son[i]]);
#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#include<algorithm>
#include<cmath>
#include<vector>
#include<stack>
#define maxn 500100
#define llg long long
using namespace std;
struct node
{
llg df,po;
}d[maxn];
llg i,j,k,n,m,p[maxn][],dad[maxn],bj[maxn],dfs[maxn],cnt,T,deep[maxn],dis[maxn],se[maxn],q,ss[maxn],open,dl[maxn];
vector <llg> a[maxn],c[maxn],val[maxn];
stack <llg> z; inline int getint(){
char c=getchar(); llg w=,q=;
while(c!='-' && ( c<'' || c>'')) c=getchar();
if(c=='-') c=getchar(),q=;
while(c>='' && c<='') w=w*+c-'',c=getchar();
return q?-w:w;
} void link(llg x,llg y,llg z) {a[x].push_back(y); val[x].push_back(z); val[y].push_back(z); a[y].push_back(x);} void link_(llg x,llg y) {c[x].push_back(y); c[y].push_back(x);} bool cmp(const node&a,const node&b){return a.df<b.df;} void find_dad_deep(llg x,llg di)
{
bj[x]=; dfs[x]=++cnt; dis[x]=di;
llg w=a[x].size();
for (llg i=;i<w;i++)
if (!bj[a[x][i]])
{
dad[a[x][i]]=x; p[a[x][i]][]=x; deep[a[x][i]]=deep[x]+;
find_dad_deep(a[x][i],min(di,val[x][i]));
}
} void build_lca()
{
for (i=;(<<i)<=n;i++)
for (j=;j<=n;j++)
p[j][i]=p[p[j][i-]][i-];
} llg lca(llg x,llg y)
{
if (deep[x]<deep[y]) swap(x,y);
for (llg i=;i>=;i--) if (deep[p[x][i]]>=deep[y]) x=p[x][i];
if (x==y) return x;
for (llg i=;i>=;i--)
if (p[x][i]!=p[y][i]) {x=p[x][i]; y=p[y][i];}
return dad[x];
} llg st[maxn],top; void make_tree(llg x)
{
llg L=,g1,g2;
while(top)
{
g1=st[top];g2=st[top-];L=lca(g1,x);
if(deep[g2]>deep[L]) link_(g2,g1),top--;
else if(deep[g2]<deep[L]) {link_(g1,L);top--;break;}
else break;
}
if(st[top]!=L) st[++top]=L;
st[++top]=x;
} void ceshi()
{
for (llg i=;i<=n;i++)
{
llg w=c[i].size();
for (llg j=;j<w;j++) if (i<c[i][j]) cout<<i<<" "<<c[i][j]<<endl;
}
} llg dp(llg x)
{
bj[x]=;
dl[++open]=x;
llg w=c[x].size(),tot=;
for (llg i=;i<w;i++)
if (!bj[c[x][i]])
tot+=dp(c[x][i]);
if (ss[x]) return dis[x];
return min(tot,dis[x]);
} int main()
{
freopen("a.in","r",stdin); freopen("a.out","w",stdout);
cin>>n;
for (i=;i<n;i++)
{
llg x,y,z;
x=getint(),y=getint(),z=getint();
link(x,y,z);
}
deep[]=;
llg ggg=(llg)1e60;
find_dad_deep(,ggg); //dis[1]=0;
build_lca();
cin>>T; for (i=;i<=n;i++) bj[i]=;
while (T--)
{
m=getint();
llg x;
for (i=;i<=open;i++) {ss[se[i]]=; c[dl[i]].clear(); bj[dl[i]]=;}
q=,open=;
c[].clear(); bj[]=; ss[]=;
for (i=;i<=m;i++) {x=getint(); d[i].po=x; d[i].df=dfs[x]; q++; ss[x]=; se[q]=x; }
sort(d+,d+m+,cmp);
top=;
if (d[].po!=) st[++top]=;
for (i=;i<=m;i++) make_tree(d[i].po);
while(top!=) link_(st[top],st[top-]),top--;
//if (q<=0) printf("0\n"); else
printf("%lld\n",dp());
//ceshi();
//cout<<endl;
}
return ;
}
BZOJ 2286: [Sdoi2011]消耗战的更多相关文章
- bzoj 2286: [Sdoi2011]消耗战 虚树+树dp
2286: [Sdoi2011]消耗战 Time Limit: 20 Sec Memory Limit: 512 MB[Submit][Status][Discuss] Description 在一 ...
- bzoj 2286 [Sdoi2011]消耗战(虚树+树上DP)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2286 [题意] 给定一棵树,切断一条树边代价为ci,有m个询问,每次问使得1号点与查询 ...
- bzoj 3611: [Heoi2014]大工程 && bzoj 2286: [Sdoi2011消耗战
放波建虚树的模板. 大概是用一个栈维护根节点到当前关键点的一条链,把其他深度大于lca的都弹出去. 每次做完记得复原. 还有sort的时候一定要加cmp!!! bzoj 3611 #include&l ...
- BZOJ 2286: [Sdoi2011]消耗战 虚树 树形dp 动态规划 dfs序
https://www.lydsy.com/JudgeOnline/problem.php?id=2286 wa了两次因为lca犯了zz错误 这道题如果不多次询问的话就是裸dp. 一棵树上多次询问,且 ...
- BZOJ.2286.[SDOI2011]消耗战(虚树 树形DP)
题目链接 BZOJ 洛谷P2495 树形DP,对于每棵子树要么逐个删除其中要删除的边,要么直接断连向父节点的边. 如果当前点需要删除,那么直接断不需要再管子树. 复杂度O(m*n). 对于两个要删除的 ...
- BZOJ 2286 [Sdoi2011]消耗战(虚树+树形DP)
[题目链接] http://www.lydsy.com/JudgeOnline/problem.php?id=2286 [题目大意] 出一棵边权树,每次给出一些关键点,求最小边割集, 使得1点与各个关 ...
- bzoj 2286: [Sdoi2011消耗战
#include<cstdio> #include<iostream> #define M 1000009 #define N 250009 #define ll long l ...
- bzoj 2286 [Sdoi2011]消耗战 虚树+dp
题目大意:多次给出关键点,求切断边使所有关键点与1断开的最小费用 分析:每次造出虚树,dp[i]表示将i和i子树与父亲断开费用 对于父亲x,儿子y ①y为关键点:\(dp[x]\)+=\(dismn( ...
- BZOJ 2286: [Sdoi2011消耗战 [DP 虚树]
传送门 题意: 删除价值和最小的边使得$1$号点与$k$个关键点不连通 一个树形DP...但是询问多次,保证总的关键点数为$O(n)$ 先说一下这个$DP$ $f[i]$表示子树$i$中的关键点与$1 ...
随机推荐
- Emgu 决策树
MCvDTreeParams cvFolds //If this parameter is >1, the tree is pruned using cv_folds-fold cross va ...
- Maven-007-Nexus 用户添加,用户角色分配,用户修改密码,管理员重置用户密码
配置好 maven nexus 私服后,默认的用户可通过查看[Users]查看当前私服中所存在的用户,如下图所示:
- IEnumerable、GetEnumerator、IEnumerator的理解
概念文字性的东西,我们就不说了,这里我们来点具体的实例第呀: 实例一: using System; using System.Collections; using System.Collections ...
- Linux下dns服务器搭建
Linux下dns服务器搭建1-环境Red Hat Enterprise Linux Server release 6.7 (Santiago)2-配置本地yum源安装dns相关包yum -y ins ...
- jQuery 中 attr() 和 prop() 方法的区别
前几天,有人给 Multiple Select 插件 提了问题: setSelects doesn't work in Firefox when using jquery 1.9.0 一直都在用 jQ ...
- C# gridControl 部分设置
1.页数导航状态栏 2.列表行号栏 3.列标题显示隐藏 4.Button设置
- magento -- 解决magento错误:ERROR: Base table or view already exists: 1050 Table ... already exists
相信有更新magento或者,备份转移magento站点的时候可能会碰到类似这样的错误提示: Base table or view already exists: 1050 Table ... alr ...
- delphi学习笔记1
快捷键CTRL+ENTER 定位到单元文件 F6快速查找文件 uses语句和include 指令 C++程序员应该知道uses语句和include 指令是不同的.uses语句只是用于输入引用单元的预编 ...
- Netty之有效规避内存泄漏
有过痛苦的经历,特别能写出深刻的文章 —— 凯尔文. 肖 直接内存是IO框架的绝配,但直接内存的分配销毁不易,所以使用内存池能大幅提高性能,也告别了频繁的GC.但,要重新培养被Java的自动垃圾回收惯 ...
- sdutoj 2608 Alice and Bob
http://acm.sdut.edu.cn/sdutoj/problem.php?action=showproblem&problemid=2608 Alice and Bob Time L ...