贪心算法与回溯算法详解:概念、应用场景及区别
创作时间:
作者:
@小白创作中心
贪心算法与回溯算法详解:概念、应用场景及区别
引用
1
来源
1.
https://www.cnblogs.com/smileZAZ/p/18164330
贪心算法和回溯算法是算法设计中的两种重要思想。贪心算法通过一系列局部最优选择来达到全局最优,而回溯算法则通过递归和回溯的方式尝试所有可能的解。本文将详细介绍这两种算法的基本概念、应用场景以及它们之间的区别。
一、贪心算法
贪心算法,又称贪婪算法,是算法设计中的一种思想。其期待每一个阶段都是局部最优的选择,从而达到全局最优,但是结果并不一定是最优的。
举个零钱兑换的例子,如果你有1元、2元、5元的钱币数张,用于兑换一定的金额,但是要求兑换的钱币张数最少。如果现在你要兑换11元,按照贪心算法的思想,先选择面额最大的5元钱币进行兑换,那么就得到11 = 5 + 5 + 1 的选择,这种情况是最优的。但是如果你手上钱币的面额为1、3、4,想要兑换6元,按照贪心算法的思路,我们会 6 = 4 + 1 + 1这样选择,这种情况结果就不是最优的选择。
从上面例子可以看到,贪心算法存在一些弊端。使用到贪心算法的场景,都会存在一个特性:
- 一旦一个问题可以通过贪心法来解决,那么贪心法一般是解决这个问题的最好办法。
至于是否选择贪心算法,主要看是否有如下两大特性:
- 贪心选择:当某一个问题的整体最优解可通过一系列局部的最优解的选择达到,并且每次做出的选择可以依赖以前做出的选择,但不需要依赖后面需要做出的选择。
- 最优子结构:如果一个问题的最优解包含其子问题的最优解,则此问题具备最优子结构的性质。问题的最优子结构性质是该问题是否可以用贪心算法求解的关键所在。
二、回溯算法
回溯算法,也是算法设计中的一种思想,是一种渐进式寻找并构建问题解决方式的策略。回溯算法会先从一个可能的工作开始解决问题,如果不行,就回溯并选择另一个动作,知道将问题解决。
使用回溯算法的问题,有如下特性:
- 有很多路,例如一个矩阵的方向或者树的路径。
- 在这些的路里面,有死路也有生路,思路即不符合题目要求的路,生路则符合。
- 通常使用递归来模拟所有的路。
常见的伪代码如下:
result = []
function backtrack(路径, 选择列表):
if 满足结束条件:
result.add(路径)
return
for 选择 of 选择列表:
做选择
backtrack(路径, 选择列表)
撤销选择
重点解决三个问题:
- 路径:也就是已经做出的选择。
- 选择列表。
- 结束条件。
例如经典使用回溯算法为解决全排列的问题,如下:
一个不含重复数字的数组 nums
,我们要返回其所有可能的全排列,解决这个问题的思路是:
- 用递归模拟所有的情况。
- 遇到包含重复元素的情况则回溯。
- 收集到所有到达递归终点的情况,并返回。
用代码表示则如下:
var permute = function(nums) {
const res = [], path = [];
backtracking(nums, nums.length, []);
return res;
function backtracking(n, k, used) {
if(path.length === k) {
res.push(Array.from(path));
return;
}
for (let i = 0; i < k; i++ ) {
if(used[i]) continue;
path.push(n[i]);
used[i] = true; // 同支
backtracking(n, k, used);
path.pop();
used[i] = false;
}
}
};
三、总结
前面也初步了解到分而治之、动态规划,现在再了解到贪心算法、回溯算法。其中关于分而治之、动态规划、贪心策略三者的求解思路如下:
其中三者对应的经典问题如下图:
参考文献
热门推荐
几万人排队许愿,几百块的手串卖到脱销,北京这座庙到底什么来头
北塔:古寺繁华 风采更胜
科技与服装设计的融合:引领时尚的未来趋势
家装水管材料选择及管径大小的确定
西部创投之都,成都如何悄悄崛起
清东陵守陵人的前世今生:从皇家守护者到文化传承者
《博德之门3》守陵人使用攻略:功能详解与技巧分享
妙佑医疗国际:减压是控制高血压的关键
野鸭蛋的孵化方法,需保持适温前期要频繁翻蛋
蛋孵化的奥秘:关键因素与方法详解
北大研究证实:这种中国饮食模式降压效果堪比药物
《中国高血压防治指南》发布:健康生活方式是预防高血压的关键
岳阳五大特色小吃:品味湖湘美食的文化传承
岳阳名菜君山银针鸡片:茶香鸡嫩,千年传承
纪录片热映:红旗饭庄的津菜传奇
科技护航 让文物古建“长寿”又“长安”
排列五第25032期开奖:中奖号码39270,你中了吗?
3D打印技术在文化遗产保护中的应用
新版达摩出装技巧:轻松实现1v5!
新版达摩出装攻略:从新手到大神!
王者荣耀达摩最新攻略:出装、铭文与实战技巧详解
NASA联手蓝色起源:2029年揭秘“毁神星”
2029年阿波菲斯飞掠:一场科学探索与行星防御的双重盛宴
秋冬养生新宠:枳术汤调理肠胃
李东垣与张仲景的中医古方:枳术汤
苗银和纯银的区别,教你快速辨别苗银、足银和纯银!
足银和纯银的区别是什么?哪款价格更高?
鼠目寸光:一个成语背后的智慧
十二生肖陪你过个吉祥年!
数学揭示:彩票中奖概率到底有多低?