oj-贪心算法

贪心算法是一种在每一步选择中都采取在当前状态下最好或最优(即最有利)的选择,从而希望导致结果是全局最好或最优的算法。本文介绍了贪心算法的基本特性,并通过分发糖果的问题举例说明其应用和解题策略。
摘要由CSDN通过智能技术生成

       贪心算法(又称贪婪算法)是指,在对问题求解时,总是做出在当前看来是最好的选择。也就是说,不从整体最优上加以考虑,他所做出的是在某种意义上的局部最优解。贪心算法不是对所有问题都能得到整体最优解,关键是贪心策略的选择,选择的贪心策略必须具备无后效性,即某个状态以前的过程不会影响以后的状态,只与当前状态有关。

特性
贪心算法可解决的问题通常大部分都有如下的特性:

⑴有一个以最优方式来解决的问题。为了构造问题的解决方案,有一个候选的对象的集合:比如不同面值的硬币。

⑵随着算法的进行,将积累起其它两个集合:一个包含已经被考虑过并被选出的候选对象,另一个包含已经被考虑过但被丢弃的候选对象。

⑶有一个函数来检查一个候选对象的集合是否提供了问题的解答。该函数不考虑此时的解决方法是否最优。

⑷还有一个函数检查是否一个候选对象的集合是可行的,也即是否可能往该集合上添加更多的候选对象以获得一个解。和上一个函数一样,此时不考虑解决方法的最优性。

⑸选择函数可以指出哪一个剩余的候选对象最有希望构成问题的解。

⑹最后,目标函数给出解的值。

贪心算法

定义

贪心的本质是选择每一阶段的局部最优,从而实现全局最优。

举例

有一堆钞票,你可以拿走十张,如果想拿走最大数额的钱,那么要怎么拿?

一定是每次拿面额最大的钞票,最丝结果就是拿走最大数领的钱

每次拿面额最大的钞票就是局部夏7。上5以卒专最:双额的就是全局最优。

策略

贪心算法并没有固定的套路,

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值