五大算法思想—贪心算法

贪心法理解

  贪心法在解决问题的策略上目光短浅,只根据当前已有的信息就做出选择,而且一旦做出了选择,不管将来有什么结果,这个选择都不会改变。换言之,贪心法并不是从整体最优考虑,它所做出的选择只是在某种意义上的局部最优。

  一句话:不求最优,只求可行解。

判断贪心法

  对于一个具体的问题,怎么知道是否可用贪心算法解此问题,以及能否得到问题的最优解?

  我们可以根据贪心法的2个重要的性质去证明:贪心选择性质和最优子结构性质

  1、贪心选择性质

  什么叫贪心选择?从字义上就是贪心也就是目光短线,贪图眼前利益,在算法中就是只根据当前已有的信息就做出选择,而且以后都不会改变这次选择。(这也是和动态规划法的主要区别)

  和动态规划法的区别:动态规划算法通常以自底向上的方式解各子问题,而贪心算法则通常以自顶向下的方式进行,以迭代的方式作出相继的贪心选择,每作一次贪心选择就将所求问题简化为规模更小的子问题。

  所以对于一个具体问题,要确定它是否具有贪心选择性质,必须证明每做一步贪心选择是否最终导致问题的整体最优解。

  2、最优子结构

  当一个问题的最优解包含其子问题的最优解时,称此问题具有最优子结构性质。

  这个性质和动态规划法的一样,最优子结构性质是可用动态规划算法或贪心算法求解的关键特征。

区分动态规划和贪心

  以二叉树遍历为例:

   贪心法是从上到下只进行深度搜索,也就是说它从根节点一口气走到黑的,它的代价取决于子问题的数目,也就是树的高度,每次在当前问题的状态上作出的选择都是1,不进行广度搜索,所以最终它得出的解不一定是最优解,很有可能是近似最优解。

  而动态规划法在最优子结构的前提下,从树的叶子节点开始向上进行搜索,并且在每一步都根据叶子节点的当前问题的状况作出选择,从而作出最优决策,所以她的代价是子问题的个数和可选择的数目,它求出的解一定是最优解。

贪心法求解问题

  使用贪心法求解可以根据以下几个方面进行(最终也对应着每步代码的实现)

  1、候选集合C

    通过一个候选集合C作为问题的可能解,即问题的最终解均取自于候选集合C。例如,在付款问题中,各种面值的货币构成候选集合。

  2、解集合S

    每完成一次贪心选择,将一个解放入S,最终获得一个完整解S

  3、解决函数solution

    检查解集合S是否构成问题的完整解。例如,在付款问题中,解决函数是已付出的货币金额恰好等于应付款。

  4、选择函数select

    即贪心策略,这是贪心法的关键,它指出哪个候选对象最有希望构成问题的解,选择函数通常和目标函数有关。例如,在付款问题中,贪心策略就是在候选集合中选择面值最大的货币。

  5、可行函数feasible

    检查解集合中加入一个候选对象是否可行,即解集合扩展后是否满足约束条件。例如,在付款问题中,可行函数是每一步选择的货币和已付出的货币相加不超过应付款。

贪心法的一般过程如下:(一般试题就是在这个基础上添加具体的实现)

  

Greedy(C)  //C是问题的输入集合即候选集合

{

    S={ }; //初始解集合为空集

    while (not solution(S))  //集合S没有构成问题的一个解

    {

       x=select(C);    //在候选集合C中做贪心选择

       if feasible(S, x)  //判断集合S中加入x后的解是否可行

          S=S+{x};

          C=C-{x};

    }

    return S;

}

小结

  像找零问题,背包问题,最近临点都是很经典的贪心算法,而且都是实际的问题,理解上不太难,对于算法题,在理解算法思想的基础上,多做题,查找规律,多总结一些C实现中重要的代码段。

五大算法思想—贪心算法,布布扣,bubuko.com

时间: 2024-10-26 21:22:37

五大算法思想—贪心算法的相关文章

算法思想——分治算法

一.分治策略 “分而治之”,大问题能够拆成相似的小问题,记住这些小问题需要具有相似性.而后将小问题的每个解合成为大问题的解.所以说大问题如何拆,小问题如何合并才是这个算法最主要的一个思想.实际上很多算法如贪心算法,动态规划等等都是要求把大问题拆成小问题.而分治算法的重要一点就是要适用于能够重新把小问题的解合并为大问题的解. 二.分治法适用条件 1.该问题的规模缩小到一定程度就可以很容易解决: 2.该问题可以分解为若干个规模较小的相同问题,这里注意是最优子结构性质: 3.利用该问题分解出的子问题的

算法导论--贪心算法与动态规划(活动选择问题)

活动选择问题 有一个教室,而当天有多个活动,活动时间表如下:找出最大兼容活动集!活动已按结束时间升序排序. 动态规划 采用动态规划需要满足两个条件:1.最优子结构2.子问题重叠 令Sij表示在ai结束后和aj开始前活动的集合,假定Aij为活动集合Sij的最大兼容子集,其中包含活动ak.问题变成求Sik与Skj最大兼容活动子集Aik与Akjz.我们用c[i,j]表示Sij的最优解的大小. 则c[i,j] = c[i,k]+c[k,j]+1;最后我们需要遍历所有可能的k值,找出最大的一个划分作为c[

五大常用算法之三贪心算法

贪心算法 贪心算法简介: 贪心算法是指:在每一步求解的步骤中,它要求"贪婪"的选择最佳操作,并希望通过一系列的最优选择,能够产生一个问题的(全局的)最优解. 贪心算法每一步必须满足一下条件: 1.可行的:即它必须满足问题的约束. 2.局部最优:他是当前步骤中所有可行选择中最佳的局部选择. 3.不可取消:即选择一旦做出,在算法的后面步骤就不可改变了. 贪心算法案例: 1.活动选择问题  这是<算法导论>上的例子,也是一个非常经典的问题.有n个需要在同一天使用同一个教室的活动a

简单理解算法篇--贪心算法

贪心算法是什么意思?举个例子就很清楚了:现在你有一个能装4斤苹果的袋子,苹果有两种,一种3斤一个,一种2斤一个,怎么装才能得到最多苹果?当然我们人考虑的话当然是拿两个2斤的苹果,就刚好装满了,但是如果按贪心算法拿的话,首先就要把最重的苹果拿下(是不是很符合贪心两个字?),但并没有得到最多苹果. 贪心算法保证了局部最优,但并不能保证得到最优解. 什么时候用贪心法?满足下面两个条件 1.       具有最优子结构 2.       贪心选择性 第1点跟动态规划的条件一样,其实贪心跟动态规划一样,都

回溯算法 和 贪心算法(全排列)

一:简介 (1)回溯法 又称试探法 回溯法的基本做法是深度优先搜索,是一种组织得井井有条的.能避免不必要重复搜索的穷举式搜索算法:基本思想是:从一条路往前走,能进则进,不能进则退回来,换一条路再试. 适用场景:当遇到某一类问题时,它的问题可以分解,但是又不能得出明确的动态规划或是递归解法,此时可以考虑用回溯法解决此类问题.回溯法的优点在于其程序结构明确,可读性强,易于理解,而且通过对问题的分析可以大大提高运行效率.但是,对于可以得出明显的递推公式迭代求解的问题,还是不要用回溯法,因为它花费的时间

算法导论----贪心算法,删除k个数,使剩下的数字最小

先贴问题: 1个n位正整数a,删去其中的k位,得到一个新的正整数b,设计一个贪心算法,对给定的a和k得到最小的b: 一.我的想法:先看例子:a=5476579228:去掉4位,则位数n=10,k=4,要求的最小数字b是n-k=6位的: 1.先找最高位的数,因为是6位数字,所以最高位不可能在后5位上取到(因为数字的相对顺序是不能改变的,假设如果取了后五位中倒数第5位的7,则所求的b就不可能是6位的了,最多也就是4位的79228)理解这点很重要!所以问题变成从第1位到第k+1(n-(n-k-1))取

[算法导论]贪心算法(greedy algorithm)

转载请注明出处:http://www.cnblogs.com/StartoverX/p/4611544.html 贪心算法在每一步都做出当时看起来最佳的选择.也就是说,它总是做出局部最优的选择,寄希望(证明)这样的选择能够导致全局最优解. 贪心算法和动态规划都依赖于最优子结构,也就是一个问题的最优解包含其子问题的最优解.不同的是,动态规划通常需要求解每一个子问题,通过对所有子问题的求解得到最终问题的解.而贪心算法寄希望于通过贪心选择来改进最优子结构,使得每次选择后只留下一个子问题,大大简化了问题

【经典算法】贪心算法

贪心算法分阶段工作.在每一个阶段,可以认为所做的决定是好的,而不考虑将来的后果.一般来说,这意味着选择的是某个局部最优.这种“眼下能够拿到的就拿”的策略是这类算法名称的来源.当算法终止时,我们希望局部最优就是全局最优.如果真是这样的话,那么算法就是正确的:否则,算法得到的是一个次最优解.如果不要求绝对的最佳答案,那么有时用简单的贪心算法生成近似答案,而不是使用一般来说产生准确答案所需要的复杂算法. 可以根据如下步骤来设计贪心算法: 1. 将优化问题转化成这样的一个问题,即像做出选择,再解决剩下的

基本算法之贪心算法

看了刘汝佳大牛的黑书果然很有体会,虽然很难,但是真的题题经典,一定要坚持坐下去,下面我们来说说贪心法 贪心算法即是每次选择局部最优策略进行实施,而不去考虑对今后的影响.贪心算法不是对所有问题都能得到整体最优解,关键是贪心策略的选择,选择的贪心策略必须具备无后效性,即某个状态以前的过程不会影响以后的状态,只与当前状态有关. 下面来看一个题目: POJ1042 钓鱼(黑书) 链接:http://poj.org/problem?id=1042 贪心:为了不讨论在路上花费的时间,可以枚举到过的湖:比如: