贪心算法

一、贪心算法的概念

贪心策略也是一种分治策略,即将大问题化为小问题,在以最优方式解决小问题后获得大问题的解。与一般分治不同的是,贪心策略每步解决的子问题数量为1个。

二、贪心算法的基本要素

贪心选择属性

贪心选择属性是指一个(全局)最优的解答是经由局部最优(贪心)的选择而获得的。

如果经由一系列贪心选择可以获得一个问题的最优解,则该问题具有所谓的贪心选择属性。

贪心算法的基本要素

贪心策略要想获得最优解,必须满足下面两个条件:

1.每个大问题的最优解里面包括下一级小问题的最优解(最优子结构性质);

2.每个小问题的解可由贪心选择获得(贪心选择性质)。

如果一个问题不具备上述条件,并不说明不能采用贪心策略,只不过贪心策略将不能保证获得最优解。

三、应用范例

0/1背包问题

k-优化算法

首先将最多k件物品放入背包,假如这k件物品重量大于c,则放弃它。否则,剩余的容量用来考虑将剩余物品按\frac{p_{i} }{w_{i}} 递减的顺序装入。通过考虑由启发法产生的解法中最多为k件物品的所有可能的子集来得到最优解。

例:考虑n=4, w=[2,4,6,7], p=[6,10,12,13], c=11。

当k=0时,背包直接按物品价值密度非递减顺序装入,首先将物品1放入背包,然后是物品2,背包剩下的容量为5个单元,剩下的物品没有一个合适的,因此解为x=[1,1,0,0],此解获得的价值为16。

现在考虑k=1时的贪婪启发法。最初的子集为{1},{2},{3},{4}。子集{1},{2}产生与k=0时相同的结果,考虑子集{3},置x_{3} 为1。此时还剩5个单位的容量,按价值密度非递增顺序来考虑如何利用这5个单位的容量。首先考虑物品1,它适合,因此取x_{1} 为1,这时仅剩下3个单位容量了,且剩余物品没有能够加入背包中的物品。通过子集{3}开始求解得结果为x=[1,0,1,0],获得的价值为18。若从子集{4}开始,产生的解为x = [1,0,0,1],获得的价值为19。考虑k为0和1时获得的最优解为[1,0,0,1],这个解是通过k=1的贪婪启发式算法得到的。

若k=2,除了考虑k<2的子集,还必需考虑子集{1,2},{1,3},{1,4},{2,3},{2,4}和{3,4}。首先从最后一个子集开始,它是不可行的,故将其抛弃,剩下的子集经求解分别得到如下结果:[1,1,0,0],[1,0,1,0],[1,0,0,1],[0,1,1,0]和[0,1,0,1],这些结果中最后一个价值为23,它的值比k=0和k=1时获得的解要高,这个答案即为启发式方法产生的结果。

算法的时间复杂度随k 的增大而增加:

需要测试的子集数目为O(n^k )

每个子集做贪心法需要时间O(n)

因此当k>0时总的时间开销为O(n*n^k)

最短路径问题

Dijkstra算法→Bellman-Ford算法

5.哈夫曼编码问题

6.最小代价生成树:Prim算法→Kruskal算法

7.拓扑排序问题

8.偶图覆盖问题

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 贪心算法的基本思想 贪心算法,是寻找最优解问题的常用方法,这种方法模式一般将求解过程分成若干个步骤,但每个步骤都应...
    结构学AI阅读 12,304评论 0 0
  • 目录 1.贪心算法步骤 2.两个关键要素 3.两种背包问题3.1 0-1背包问题(适用于动态规划,不满足贪心选择性...
    王侦阅读 10,435评论 2 3
  • 一、概念 贪心算法,又称贪婪算法,是指在对问题求解时,总是做出在当前看来是最好的选择。也就是说,不从整体最优上加以...
    TomyZhang阅读 2,629评论 0 0
  • 摘要 github网址 1.渴婴问题:婴儿可以喝n种饮料,有的可口,有的不好喝,每种都具有满意值,第i瓶即为si...
    曹_华阅读 4,270评论 0 1
  • 今天做了一件勇猛的事,给小三哥哥,送水。 我正拿着心爱的饼,走在回寝室的路上。路过篮球场,突然李景峰喊我,我很好奇...
    free8阅读 2,924评论 0 0