瀑布流引发的思考

本文从一个关于瀑布流布局的讨论出发,探讨如何最小化多列图片高度差的问题,进而转化为01背包问题。通过动态规划解释了解决01背包问题的方法,并指出将数组均分为三组的问题属于NP完全问题。最后,文章提到了贪心算法在数据均匀时对瀑布流布局的适用性,并推荐了相关论文进行深入研究。
摘要由CSDN通过智能技术生成

事件起因:有一天在某篇文章看到这样一道题目

A:你有写过瀑布流吗?

B:我写过等宽瀑布流。实现是当用户拉到底部的一定高度的时候,向后端请求一定数量的图片,然后再插入到页面中。

A:那我问一下,如何让几列图片之间的高度差最小?

B:这个需要后端发来的数据里面有图片的高度,然后我就可以看当前高度最小的是哪里列,将新图片插入那一列,然后再看看新的高度最小的是哪一列。

A:我觉得你没有理解我的问题,我的意思是如何给后端发来的图片排序,让几列图片之间的高度差最小?

B:(想了一段时间)对不起,这个问题我没有思路。

 

转化一下问题,将任意数分成特定的组,使得每组的和尽量相等

那么怎么解决这个问题呢?

记得刚接触编程的时候,有人和我说过写函数就是找规律,找到内部的共同点,我们现在就按这个方法尝试探究一下这个问题

不考虑分成一组的情况,我们直接考虑两组

在两组的情况下,很容易可以想到只要将其中一组尽可能拿到总和的1/2即可

那么这个问题就被转化为了01背包问题

条件:数组中的数就是背包问题的weight值,数组中的数也是背包问题的value值,即二者一样。

问题:背包里装哪些物品,使得其价值之和最接近总价值的一半。

01背包的处理取决于拿与不拿

简单陈述通过动态规划来求解0-1背包问题的思路。

用f(1,2,3,4....i)(j)表示背包为j时能在i个物品中取出的最大价值

<
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值