最大化最小值 | | 最小化最大值

最小化最大值.

和"河中跳房子","Agressive Cows"等最大化最小值问题正好相反的最小化最大值问题,同样用二分解决,原理基本相同,差别主要在C条件的判断上.

1.最大化最小值:

相当于n个东西分给m个人,使得每个人至少拿x个,那么每个人拿够了就走,给后面的人多留一点,只要能分够>=m个人就是true,多的全扔给最后一个人就是了.

2.最小化最大值:

相当于n个东西分给m个人,每个人至多能拿x个,那么每个人尽可能多拿一点,给后面的人少留一点,只要能使<=m个人分完这n个东西就是true,之后每个人随便拿一点给没有拿到的人就是了.

转载于:https://www.cnblogs.com/shuaihui520/p/8916753.html

"最大化最小值"或"最小化最大值"问题的函数曲线一般是非常复杂的,因为目标函数可以是任意的函数。但是,我们可以通过一个简单的例子来理解这类问题的函数曲线。 假设我们要在一个一维数组中找到一个最大的数 x,使得数组中所有数都不小于 x。我们可以将这个问题转化为一个函数 f(x) 的形式,其中 f(x) 表示 "数组中所有数都不小于 x" 这个条件是否成立。具体地,如果数组中存在一个数小于 x,则 f(x) 为 false,否则 f(x) 为 true。 这个函数的曲线是一个阶梯状的函数,如下图所示: ``` | | | | | | | | |___|___|___|___ x1 x2 x3 x4 ``` 其中,每个竖直的线段表示一个数组元素,x1、x2、x3、x4 分别表示四个元素的值,每个水平的线段表示函数值为 true 的区间。例如,当 x 取值在 [x3, x4] 区间内时,f(x) 的值都为 true,因为数组中所有元素的值都不小于 x3。 在这个例子中,我们要找到的最大的 x,就是最后一个函数值为 true 的点所对应的 x 值,即 x4。这个问题可以通过二分查找法解决,每次取中间值,判断中间值是否满足条件,然后不断缩小搜索区间,最终找到最大的 x 值。 类似的,对于"最小化最大值"问题,我们可以构造一个类似的函数,表示所有满足条件的最大值是否小于等于 x。这个函数的曲线也是一个阶梯状的函数,但是是逆向的,即从右上方向左下方延伸。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值