博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
hdu 3586 Information Disturbing(树形dp + 二分)
阅读量:6233 次
发布时间:2019-06-22

本文共 383 字,大约阅读时间需要 1 分钟。

 

本文出自   

 题目链接:   

 

题意

   给一棵n个节点的树,节点编号为1~n,根节点为1。每条边有权值,砍掉一条边要花费cost(w)

   要砍掉一些边, 使得每个叶子节点无法走到根节点。
   要求砍掉花费总和不能超过m的情况下,让每条边花费上限尽量低

思路

   二分可以砍的边的权值上限,然后树形dp

   f[i]: 表示让i子树所有的叶子节点无法到达i点的最小花费
   f[i] = sum { min(w(i,v), f[v]) | v是i的儿子节点 }
   而这题有一个上限权值,即权值大于上限的就不能去砍。
   所以上面的转移要改一下
   if (w(i, v) > 上限) f[i] += f[v];
   else  f[i] += min(w(i,v), f[v]);
   然后,如果f[1]<=m,那么这个上限就符合条件
   这一题,如果用INF初始化的话,那么INF一定要大于m的最大值1000000

 

代码

 

 

 

 

 

转载地址:http://nzhna.baihongyu.com/

你可能感兴趣的文章
电信无限流量卡
查看>>
Java反射机制的适用场景及其利与弊 ***
查看>>
wine 运行Call of Duty Modern Warfare 2以及starcraft2方法
查看>>
找出表的记录数
查看>>
实现WCF和Unity 的集成
查看>>
Java 和 C#在重写上的区别
查看>>
基础才是重中之重——对var的误会,对不起,我愿望(冤枉)你了
查看>>
集合类型的装配
查看>>
【Linux开发技术之工具使用】配置VIM下编程和代码阅读环境
查看>>
【读书笔记】测试驱动开发(中文版)
查看>>
ExtAspNet v3.0.1
查看>>
javascript 构造函数和方法
查看>>
使用VB.net Express 2010开发AutoCAD.net插件调试时出现很多错误的解决办法
查看>>
.net服务使用笔记(原创)
查看>>
使用Tomcat配置域名
查看>>
[转]Oracle/Altibase数据库中Sequence的用法
查看>>
URAL 1009 K-based Numbers
查看>>
android 知识点汇总
查看>>
android之Notification通知
查看>>
C# 生成等比缩略图的类
查看>>