理解动态规划算法与贪心算法区别----找钱问题

一、说明

 

      纠结了很久动态规划法与贪心算法的异同,光看理论文字的说明,没有能彻底搞清楚两者的区别究竟是什么。发现大家举得最多的一个

比较两者区别例子就是找钱问题。解决这个找钱问题,可以很大程度上帮助我们理解动态规划法语贪心算法的区别

 

 

二、问题

      现只有面额为 11元、5元、1元的三种人民币。

      给定一个 数目为 money 的人民币,如何用这三种面额的人民币 找开它,且用的人民币张数最少

      如:给定 10元,我们可以有以下找法:

            2张  5元面额

            1张  5元面额  + 5 张  1元面额

            10张 1元面额

      我们 选择第一种找法。只用两张人民币。

 

 

三、分析

 

利用动态规划法可以找到最优解。

        利用贪心算法可以找到最优解(问题满足贪心选择性质时。该找钱问题在 11、5、1三种面额的情况下不满足该性质)

              或者找到近似 最优解(在本题设定的三种面额的情况下 便是如此)

 

        如果现在要找开 15元钱,则

        1. 根据动态规划法的解题思想,得到最优解为       3张  5元面额的 ,                                   总共 3张

        2. 根据贪心算法的解题思想,得到的近似最优解为 1张 11元面额的  加上  4张 1元面额的,     总共 5张

 

        从这就可以大略的看到 两个的区别

 

 

四、代码实现找钱问题的 动态规划法与贪心算法 两种解法,形成对比

 

 

 

posted @ 2010-12-05 22:17  JarvisChu  阅读(544)  评论(0编辑  收藏  举报