算法学习 【第一周】 Ⅲ

简介: “贪亦有道”,了解有关贪心算法的基础知识,如果我们在生活中也按照贪心算法那样去选择会是什么样的呢?

一、前言

本期博客我们将学习算法策略之贪心算法的有关基础知识。

二、什么是贪心算法?

贪心算法是遵循在每个阶段做出局部最优选择的问题解决启发式的任何算法。[1]在许多问题中,贪心策略不会产生最优解,但贪心启发式算法可以产生局部最优解,在合理的时间内逼近全局最优解。

例如,旅行商问题(计算复杂度高)的贪心策略是以下启发式的:“在旅程的每一步,访问最近的未访问城市。” 这种启发式并不打算找到最佳解决方案,但它会在合理数量的步骤中终止;为如此复杂的问题找到最佳解决方案通常需要很多不合理的步骤。在数学优化中,贪心算法对具有拟阵性质的组合问题进行优化求解,并对具有子模结构的优化问题给出常数因子近似。

贪心算法无法为许多其他问题产生最佳解决方案,甚至可能产生唯一的最差可能解决方案。一个例子是上面提到的旅行商问题:对于每个城市数量,有一个城市之间的距离分配,最近邻启发式产生唯一的最差可能旅行。

贪心算法在解决问题的策略上"目光短浅”。贪心算法只根据当前信息做出选择,而且一旦做出选择,则不管将来有什么结果,这个选择都不会改变。换言之,贪心算法并不是从整体上做最优考虑,它所做出的选择只是某种意义上的局部最优。在实际应用中,很多问题都可以通过贪心算法得到最优解或最优解的近似解。

三、贪心算法的优缺点

  1. 优点
  • 该算法更容易描述
  • 该算法可以比其他算法执行得更好(但并非在所有情况下)
  1. 缺点
  • 贪心算法并不总是产生最优解

我们举个例子:

例如,假设我们想在下图中找到从根到叶的最长路径。让我们在这里使用贪心算法。

image-20221022154750428.png

贪心算法具体步骤:

  1. 从根节点20开始。右孩子的体重是3,左孩子的体重是2
  2. 我们的问题是找到最大的路径。并且,此时的最优解是3。所以,贪心算法会选择3
  3. 最后一个3的独生子的体重是1。这给了我们最终的结果20 + 3 + 1 = 24

但是这并不是最佳解决方法,我们还有可以有另一条路径可以得出比贪心算法更长的路径。

image-20221022154952787.png

20 + 2 + 10 = 32,因此,贪心算法并不总是给出最优/可行的解决方案。

四、贪心选择

贪心选择是指原问题的整体最优解可以通过一系列局部最优的选择得到:先做出当前最优的选择,将原问题变为一个相似却规模更小的子问题,而后的每一步都是当前最优的选择。这种选择依赖于已做出的选择,但不依赖于未做出的选择。

五、最优子结构

最优子结构是指原问题的最优解包含子问题的最优解。贪心算法通过一系列的局部最优解(子问题的最优解)得到全局最优解(原问题的最优解),如果原问题的最优解和子问题的最优解没有关系,则求解子问题没有任何意义,无法采用贪心算法。例如,对于原问题S={a1,2,...,ai,..., an},可以在通过贪心选择得到一个当前最优解{a}之后,转换为求解子问题S-{a分,继续求解该子问题,最后对所有子问题的最优解进行合并,即可得到原问题的最优解,如下图所示:

image-20221022155629456.png

六、如何创建贪心算法?

贪心算法的求解过程:

  • 第 1 步:在给定问题中,找到最佳子结构或子问题。
  • 第 2 步:确定解决方案将包括哪些内容(例如,最大和、最短路径)。
  • 第 3 步:创建一个遍历所有子问题并创建最佳解决方案的迭代过程。

七、最后我想说

本期博客主要介绍了有关贪心算法的一些基础知识,后续博客我们就会通过一系列的具体问题深入的了解学习一下贪心算法的具体应用。

最后,问大家一个不属于计算机领域的问题:如果我们在生活中也按照贪心算法那样去选择,你觉得会是什么样的呢?

北天
+关注
目录
打赏
0
0
0
1
300
分享
相关文章
数据结构与算法学习二二:图的学习、图的概念、图的深度和广度优先遍历
这篇文章详细介绍了图的概念、表示方式以及深度优先遍历和广度优先遍历的算法实现。
77 1
数据结构与算法学习二二:图的学习、图的概念、图的深度和广度优先遍历
架构学习:7种负载均衡算法策略
四层负载均衡包括数据链路层、网络层和应用层负载均衡。数据链路层通过修改MAC地址转发帧;网络层通过改变IP地址实现数据包转发;应用层有多种策略,如轮循、权重轮循、随机、权重随机、一致性哈希、响应速度和最少连接数均衡,确保请求合理分配到服务器,提升性能与稳定性。
51 11
架构学习:7种负载均衡算法策略
2024重生之回溯数据结构与算法系列学习之串(12)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丟脸好嘛?】
数据结构与算法系列学习之串的定义和基本操作、串的储存结构、基本操作的实现、朴素模式匹配算法、KMP算法等代码举例及图解说明;【含常见的报错问题及其对应的解决方法】你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
2024重生之回溯数据结构与算法系列学习之串(12)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丟脸好嘛?】
【EMNLP2024】基于多轮课程学习的大语言模型蒸馏算法 TAPIR
阿里云人工智能平台 PAI 与复旦大学王鹏教授团队合作,在自然语言处理顶级会议 EMNLP 2024 上发表论文《Distilling Instruction-following Abilities of Large Language Models with Task-aware Curriculum Planning》。
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
这篇文章详细介绍了Java虚拟机(JVM)中的垃圾回收机制,包括垃圾的定义、垃圾回收算法、堆内存的逻辑分区、对象的内存分配和回收过程,以及不同垃圾回收器的工作原理和参数设置。
136 4
JVM知识体系学习六:JVM垃圾是什么、GC常用垃圾清除算法、堆内存逻辑分区、栈上分配、对象何时进入老年代、有关老年代新生代的两个问题、常见的垃圾回收器、CMS
|
3月前
|
动态规划算法学习三:0-1背包问题
这篇文章是关于0-1背包问题的动态规划算法详解,包括问题描述、解决步骤、最优子结构性质、状态表示和递推方程、算法设计与分析、计算最优值、算法实现以及对算法缺点的思考。
141 2
动态规划算法学习三:0-1背包问题
2024重生之回溯数据结构与算法系列学习(8)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
2024重生之回溯数据结构与算法系列学习之单双链表精题详解(9)【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构王道第2.3章之IKUN和I原达人之数据结构与算法系列学习x单双链表精题详解、数据结构、C++、排序算法、java、动态规划你个小黑子;这都学不会;能不能不要给我家鸽鸽丢脸啊~除了会黑我家鸽鸽还会干嘛?!!!
2024重生之回溯数据结构与算法系列学习之单双链表【无论是王道考研人还是IKUN都能包会的;不然别给我家鸽鸽丢脸好嘛?】
数据结构之单双链表按位、值查找;[前后]插入;删除指定节点;求表长、静态链表等代码及具体思路详解步骤;举例说明、注意点及常见报错问题所对应的解决方法

热门文章

最新文章

AI助理

你好,我是AI助理

可以解答问题、推荐解决方案等