事件起因:有一天在某篇文章看到这样一道题目
A:你有写过瀑布流吗?
B:我写过等宽瀑布流。实现是当用户拉到底部的一定高度的时候,向后端请求一定数量的图片,然后再插入到页面中。
A:那我问一下,如何让几列图片之间的高度差最小?
B:这个需要后端发来的数据里面有图片的高度,然后我就可以看当前高度最小的是哪里列,将新图片插入那一列,然后再看看新的高度最小的是哪一列。
A:我觉得你没有理解我的问题,我的意思是如何给后端发来的图片排序,让几列图片之间的高度差最小?
B:(想了一段时间)对不起,这个问题我没有思路。
转化一下问题,将任意数分成特定的组,使得每组的和尽量相等
那么怎么解决这个问题呢?
记得刚接触编程的时候,有人和我说过写函数就是找规律,找到内部的共同点,我们现在就按这个方法尝试探究一下这个问题
不考虑分成一组的情况,我们直接考虑两组
在两组的情况下,很容易可以想到只要将其中一组尽可能拿到总和的1/2即可
那么这个问题就被转化为了01背包问题
条件:数组中的数就是背包问题的weight值,数组中的数也是背包问题的value值,即二者一样。
问题:背包里装哪些物品,使得其价值之和最接近总价值的一半。
01背包的处理取决于拿与不拿
简单陈述通过动态规划来求解0-1背包问题的思路。
用f(1,2,3,4....i)(j)表示背包为j时能在i个物品中取出的最大价值
<