贪心算法.

贪心算法是指只从当前角度出发,做出当前情景下最好的选择,在某种意义上来说是局部最优解,并不从全局的角度做决策.如果贪心策略选择不恰当,可能无法得到全局最优解.

贪心算法的基本流程如下:

1.分析问题,确定优化目标,对变量进行初始化

2.制定贪心策略:在制定贪心策略时需要证明所选贪心策略一定可以得到全局最优解,若找到反例则推翻当前贪心策略,重新确定贪心策略.

完全背包问题

本节以完全背包问题为例,说明贪心算法的重要性.

给定一些物品,用matrix表示各个物品的属性,第一项表示物品的质量,第二项表示物品的总价值.现有一背包最大承重为M,试求如何装入以上物品能使背包中所装物品价值最高.

1.选取价值最大的物品,优先放入背包,举反例如下:

matrix=[(20,30),(10,40),(10,30)]

M=20

根据贪心策略,首先将价值最高的1放入背包,此时背包价值为30,但是如果将物品2和3都放入背包,总价值是70.由此可见,贪心策略并不能得到最优解

2.选取重量最小的物品优先放入背包,现举反例如下:

matrix=[(10,5),(20,10),(40,50)]

M=40

根据贪心策略,首先先将重量最小的1放入背包,再将物品2放入背包,此时重量为30,物品3已经无法放入了.此时总价值为15,而直接放入物品3的总价值为50.由此可见贪心算法得不到最优解

由上述分析可以得知,在解决一个问题时,贪心策略是多种多样的,但所制定的贪心策略并不一定是最优解,并且一个贪心策略要经得起推敲,而不是轻易就可以举出反例.

相关推荐
dfsj6601114 分钟前
LLMs 系列科普文(14)
人工智能·深度学习·算法
薛定谔的算法33 分钟前
《盗梦空间》与JavaScript中的递归
算法
kaiaaaa1 小时前
算法训练第十一天
数据结构·算法
?!7141 小时前
算法打卡第18天
c++·算法
springfe01011 小时前
构建大顶堆
前端·算法
凌辰揽月2 小时前
Web后端基础(基础知识)
java·开发语言·前端·数据库·学习·算法
lifallen2 小时前
深入浅出 Arrays.sort(DualPivotQuicksort):如何结合快排、归并、堆排序和插入排序
java·开发语言·数据结构·算法·排序算法
jingfeng5142 小时前
数据结构排序
数据结构·算法·排序算法
能工智人小辰2 小时前
Codeforces Round 509 (Div. 2) C. Coffee Break
c语言·c++·算法
kingmax542120082 小时前
CCF GESP202503 Grade4-B4263 [GESP202503 四级] 荒地开垦
数据结构·算法