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

 

相关文章:

  • 2022-02-17
  • 2021-12-29
  • 2021-10-23
  • 2022-12-23
  • 2022-12-23
  • 2021-05-21
  • 2021-07-20
  • 2021-06-08
猜你喜欢
  • 2021-06-17
  • 2021-11-25
  • 2021-06-28
  • 2021-06-23
  • 2022-01-15
  • 2022-03-10
  • 2022-12-23
相关资源
相似解决方案