滑蒻稽的博客

【笔记】二分答案的两种形式

f(x1,x2,,xn)=(a1,a2,,an),要让 max{a1,a2,,an} 最小或 min{a1,a2,,an} 最大。

如果直接 DP 考虑让每一个 ai 都尽量小,是不满足最优子结构的。如果记上 max{a1,a2,,an} 进行 DP,复杂度会爆炸。

二分答案 X,DP 让每一个 ai 尽量小,但是在 DP 的过程中让不满足 aiX 的状态不进行转移。子结构间互不影响,转移到父结构的子结构都满足 aiX 的限制,DP 正确性就有保证了。

我们刚才讲的是 DP,要 DP 的话转移关系肯定是线性的,树形 DP 或者就最普通的 1D/1D DP 都算。但是像 Nudist Beach 这道题,巧妙地考虑在最优情况下也取不到的点,然后 BFS 扩展删点。

求满足函数 f(x1,x2,,xn,T)X 成立的 T 的最小值。

T 的值域极大,状态记下 T 就没法 DP。如果二分答案 T,限制就变成了判断 fT(x1,x2,,xn)X 是否成立。

posted @   huaruoji  阅读(37)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· Manus爆火,是硬核还是营销?
· 终于写完轮子一部分:tcp代理 了,记录一下
· 【杭电多校比赛记录】2025“钉耙编程”中国大学生算法设计春季联赛(1)
历史上的今天:
2019-10-19 CSP-J2019初赛游记&解题报告
2019-10-19 前缀,后缀表达式求值
点击右上角即可分享
微信分享提示