首页 > 其他 > 详细

树形dp - Codeforces Round #322 (Div. 2) F Zublicanes and Mumocrates

时间:2015-10-03 23:05:31      阅读:554      评论:0      收藏:0      [点我收藏+]

 Zublicanes and Mumocrates

Problem‘s Link


 

Mean: 

给定一个无向图,需要把这个图分成两部分,使得两部分中边数为1的结点数量相等,最少需要去掉多少条边.

analyse:

树形dp.

dp[cur][i][j]:当cur为i集合的时候 有j个和i同集合的方案

状态转移方程为:

   dp[cur][i][j+k] = min{dp[to][i^1][j=(叶子个数-d)]+dp[cur][i][k]+1,dp[to][i][j]+dp[cur][i][k]}

cnt为叶子节点的个数.

最后答案是:min{ dp[root][0][cnt/2] ,dp[root][1][cnt/2]}

Time complexity: O(N)

 

view code

 

树形dp - Codeforces Round #322 (Div. 2) F Zublicanes and Mumocrates

原文:http://www.cnblogs.com/crazyacking/p/4853943.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!