jzoj5906
我們首先發現,每一條邊都至少走1次,因為我們必須走到每一個節點按按鈕
如果我們不走一個節點,說明這個節點已經有傳送門了,但是必須走到這個節點開傳送門,矛盾
然後我們發現,每一條邊至多經過2次
如果我們將傳送門設置在一個祖先,則邊fa->i會經過兒子個數次
但是如果將傳送門設置在兒子u處,則邊fa->i只會經過2次,更優
我們再次發現,傳送的位置和第一個傳送門有關係,而和第二個無關
所以我們可以先設置兒子的傳送門,再設置父親的傳送門
顯然,設置傳送門可以讓一些邊只走1次,我們可以計算最優方案
記dp[i][0/1]表示在/不在i點設置傳送門的單邊權值之和
若設置傳送門於祖先,則為了保證祖先的邊只走2次或者以下,則只能放一個孩子到祖先,其他都老老實實的走2遍
所以dp[i][1]=max(dp[i][1],dp[v[i]][1]+w[i])
若設置傳送門于當前點或者孩子,那麼我們可以走孩子邊
由於我們設置傳送門在孩子不會影響到父親,所以我們可以綜合選和不選的方案
所以dp[i][0]= sigma max(dp[v[i]][0],dp[v[i]][1]+w[i])
表示現在我們在v[i]設置傳送門的方案,與不在v[i]設置傳送門的方案
#include<bits/stdc++.h>
using namespace std;
typedef long long ll;
ll n,v[2000010],w[2000010],nxt[2000010],ec,h[1000010],dp[1000010][2];
void add(ll x,ll y,ll z){v[++ec]=y;w[ec]=z;nxt[ec]=h[x];h[x]=ec;}
void dfs(ll x,ll p){
for(ll i=h[x];i;i=nxt[i])
if(p!=v[i]){
dfs(v[i],x);
dp[x][1]=max(dp[x][1],dp[v[i]][1]+w[i]);
dp[x][0]+=max(dp[v[i]][0],dp[v[i]][1]+w[i]);
}
}
int main(){
freopen(“portal.in”,“r”,stdin);
freopen(“portal.out”,“w”,stdout);
ll ans=0;
scanf("%lld",&n);
for(ll i=1;i<n;i++){
ll a,b,c;
scanf("%lld%lld%lld",&a,&b,&c);
ans+=c*2;
add(a,b,c);add(b,a,c);
}
dfs(1,0);
printf("%lld",ans-dp[1][0]);
}
jzoj5906的更多相关文章
- <JZOJ5906>传送门
emmm dpdpdp然鹅我考场上并想不到 还是凉凉 #include<cstdio> #include<cmath> #include<iostream> #in ...
- NOIP前的刷题记录
因为这几天要加油,懒得每篇都来写题解了,就这里记录一下加上一句话题解好了 P4071 [SDOI2016]排列计数 组合数+错排 loj 6217 扑克牌 暴力背包 P2511 [HAOI2008 ...
随机推荐
- dedecms连表查询参照
ixingmeib2c/ds/entity_clas/tc_coupon_index.ls.php下面的getIndexInfo()方法
- PhpStorm 注册相关
网址 http://idea.lanyus.com/ 最新(2017年9月)PhpStorm 2017.3 .WebStorm 2017.2.5.PyCharm 2016.3激活方式 打开网址 ht ...
- Jmeter如何把CSV文件的路径设置成一个变量,且变量的值是一个相对路径
首先,在Jmeter中,通过User Defined Variables设置一个变量用来存储CSV文件所在文件夹的相对路径 备注: 这个相对路径前面不要加.\ 加了的话在运行的时候会报错,提示找不到那 ...
- 20155333 2016-2017-2 《Java程序设计》第五周学习总结
20155333 2016-2017-2 <Java程序设计>第五周学习总结 教材学习内容总结 1.使用try.catch语法 与C语言中程序流程和错误处理混在一起不同,Java中把正常流 ...
- hadoop学习笔记(五):java api 操作hdfs
HDFS的Java访问接口 1)org.apache.hadoop.fs.FileSystem 是一个通用的文件系统API,提供了不同文件系统的统一访问方式. 2)org.apache.hadoop. ...
- 初识Java ThreadLocal
转载自:https://www.cnblogs.com/dreamroute/p/5034726.html ThreadLocal翻译成中文比较准确的叫法应该是:线程局部变量. 这个玩意有什么用处,或 ...
- java使用WebUploader做大文件的分块和断点续传
版权所有 2009-2018荆门泽优软件有限公司 保留所有权利 官方网站:http://www.ncmem.com/ 产品首页:http://www.ncmem.com/webapp/up6.2/in ...
- MySQL中不允许使用列别名作为查询条件
在MySQL中有个特殊的规定,即不允许使用列别名作为查询条件.比如有下面一个表: select ID, title, concept, conceptLength, ...
- Android-AndroidStudio莫名其妙的错误-finished with non-zero exit value 1
上一篇博客,Android-AndroidStudio莫名其妙的错误-finished with non-zero exit value 1,解决了由于 string.xml 字符导致的: 而这篇博客 ...
- .NET Core 类库中读取appsettings.json
{ "Logging": { "IncludeScopes": false, "LogLevel": { "Default&quo ...