写在前面:
贪心算法是要持续去学习的,其他算法学完之后,就可以做别的题,而贪心算法不是,需要一直去学习,碰见新的题型很正常。
什么是贪心算法?
贪心算法是解决问题的策略,也就是解决问题的方法。这个方法就是利用局部最优的方法推出全局最优。
1.把解决问题的方法分成若干步。然后分布去解决问题。
2.解决每一步的时候,都选择当前看起来“最优的”解法。
3."希望"得到全局最优解
看见这三步的时候,我会有两个问题,
1.怎么选择当前看起来“最优的”解法。
2.为什么是“希望”得到全局最优解,而不是得到全局最优解
接下来举例子
1.找零钱问题
我们现在是老板,假设我们有无限个面值为20,10,5,1的纸币,现在要求我们用最少的张数的纸币去找零。
顾客用50块钱来买4块钱的东西,我们需要找零46.
找零的时候我们肯定是一步一步给你找零钱,这个一步一步找零钱也就相当于我们的第一步将这个问题分成若干个小问题。第二步是,要选择当前看起来“最优的”解法。,就是要用最快凑够这46块钱,因此最优解法,应该是用小于当前钱数的最大的面值去找零。
第一步,46,用最大的面值用来找零,也就是20的面值来找钱,剩下26;
第二步, 剩下26 ,还是用最大的面值用来找零,也就是20的面值,剩下6;
第三步,剩下6,用最大的面值的用来找零,5的面值,剩下1;
第四步,剩下1,用最大的面值用来找零,1的面值,剩下0;