钞票找零问题是一个非常古老的问题,百度那些都有,本文将一步步的讲解关于钞票找零的算法以及优化过程.
贪心算法
假设有1,2,5,10面值的钞票,现在需要找零89元,我们该怎么做呢?...这时候我们就需要用到贪心算法
贪心算法是指,在每一次情况下,都选择当前最优的解进行处理,
在这个场景里面,最优的解就应该是从大到小进行找零了,89块钱,先找最大面值的50块钱,然后找10块钱的,以此类推...(11-3*3=2,11-2*5=1),但其实11元是有解的(2*3+5)
这时候,我们需要在贪心算法的基础上,进行相应的规划(当每次找一个最优解时,尝试通过该解之后继续寻找,但是找零方法只记录到缓存中...通过上面的算法,我们实现了简单的动态规划
使其在面额为3,5,找零11元的情况下,被金额5"贪心迷惑",找2个金额5,导致算法无解
这个算法实现了在这种情况下,不贪心,不被眼前的2*5迷惑,为了"大局...当面额只有1,30,50,找零90的情况下,根据贪心+规划算法,我们能得到50*1+30*1+1*10的情况,这需要用到12张钞票,但是实际情况我们只需要找30*3,3张钞票即可解决该问题.这代表着我们需要完全遍历所有能找零的方法