贪婪算法详解(思想步骤以及经典例子)

贪婪算法详解(思想步骤以及经典例子)-mikechen

贪婪算法是五大常用算法之一,需要掌握,本文会详细介绍贪婪算法的基本思想及其代码实现例子@mikechen

贪婪算法定义

贪婪算法,英文名为Greedy Algorithm,又名贪心算法

贪婪算法,是指所求问题的整体最优解可以通过一系列局部最优的选择,即贪心选择来达到。

 

贪婪算法原理思想

贪婪算法的基本思路,主要分为如下三步:

步骤1:从某个初始解出发;

步骤2:采用迭代的过程,当可以向目标前进一步时,就根据局部最优策略,得到一部分解,缩小问题规模;

步骤3:将所有解综合起来。

 

贪婪算法的应用场景

简单地说,问题能够分解成子问题来解决,子问题的最优解能递推到最终问题的最优解,就可以使用贪婪算法。

比如:贪婪算法可以解决一些最优化问题,如:求图中的最小生成树,求哈夫曼编码等。

 

 

贪婪算法经典例子

1.找零钱的例子

1)题目

指定币值和相应的数量,用最少的数量凑齐某金额。

 

2)思路

利用贪婪算法,基本思路:我们优先选择面值大的钱币,以此类推,直到凑齐总金额。

 

3)算法实现

贪婪算法详解(思想步骤以及经典例子)-mikechen

 

2.活动选择例子

1)题目

有这么一堆数,按照金字塔排列下来,如下图所示:

贪婪算法详解(思想步骤以及经典例子)-mikechen

我们从顶点开始,求从顶部到底部的最大路径之和。

 

2)思路

利用贪婪算法,基本思路:要是用眼瞅,比较容易能看出来最佳路径是9-7-3-4-5,但是如果数一多,眼瞅就不好使了,此时就得靠代码去算。

 

3)算法实现

// 注意,下面的代码只是表意,不能直接扒过去用
// a[i][j]表示数组,maxJ表示数组的最大层数,temp表示临时数值
// maxJ表示总列数,maxI表示当前列的最大行数
 
for(j=0; j<maxJ; j++){
    for(i=0; i<maxI; i++){
        temp1 = a[i][j] + a[i][j+1];
        temp2 = a[i][j] + a[i+1][j+1];
        temp = max(temp1, temp2);
    }
    maxSum = maxSum + temp;
}
return maxSum;

 

mikechen睿哥

mikechen睿哥,十余年BAT架构经验,资深技术专家,就职于阿里、淘宝、百度等一线互联网大厂。

关注「mikechen」公众号,获取更多技术干货!

后台回复面试即可获取《史上最全阿里Java面试题总结》,后台回复架构,即可获取《阿里架构师进阶专题全部合集

评论交流
    说说你的看法