01分数规划

01分数规划

01分数规划模型大多都能化成对这样的一个式子求最值的问题↓

ans=xiaixibi,xi{0,1}

具体而言,就是有一对元素,每个元素有两个属性,从中挑选出一些元素使得属性一的和比上属性二的和最大。
我们采用二分解决这个问题,首先假设答案为ans,对原式化简:

xiaiansxibi=0

把ans丢进去

xiaiansxibi=0

化简

xiaiansxibi=0

考虑二分的值 mid, 如果 mid > ans 则上式的值 < 0,其他情况同理,所以问题转化成了求上式ans = mid时的最大值。
从若干物品中选出价值和最大的,每个物品可以选1次或不选,01背包实现。
所以整个问题的思路就明确了:
1.二分一个值
2.01背包计算max
3.如果 max < 0, r = mid - 1,否则 l = mid + 1;

模板题:Talent Show G

posted @   Kun_9  阅读(29)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 单线程的Redis速度为什么快?
· 展开说说关于C#中ORM框架的用法!
· Pantheons:用 TypeScript 打造主流大模型对话的一站式集成库
· SQL Server 2025 AI相关能力初探
· 为什么 退出登录 或 修改密码 无法使 token 失效
点击右上角即可分享
微信分享提示