首頁 >Java >java教程 >動態規劃之找零問題詳解

動態規劃之找零問題詳解

零下一度
零下一度原創
2017-07-20 13:35:002881瀏覽

  找零問題:需找零金額為W,硬幣面額有(d1, d2, d3,…,dm),最少需要多少枚硬幣。

  問題:需找零金額為8,硬幣面額有(1, 3, 2, 5),最少需要多少枚硬幣。

  設F(j)表示總金額為j時最少的零錢數,F(0) = 0,W表示找零金額,有零錢一堆{d1, d2, d3,…,dm} 。同樣根據先前的經驗,要達到為j,那麼必然是j – di(1 <= i <= m)面值的硬幣數再加1個di面值的硬幣,當然j >= di,即F (j) = F(j - di) + 1, j >= di。

  Java

 1 package com.algorithm.dynamicprogramming; 2  3 import java.util.Arrays; 4  5 /** 6  * 找零问题 7  * Created by yulinfeng on 7/5/17. 8  */ 9 public class Money {10     public static void main(String[] args) {11         int[] money = {1, 3, 2, 5};12         int sum = 8;13         int count = money(money, sum);14         System.out.println(count);15     }16 17     private static int money(int[] money, int sum) {18         int[] count = new int[sum + 1];19         count[0] = 0;20         for (int j = 1; j < sum + 1; j++) { //总金额数,1,2,3,……,sum21             int minCoins = j;22             for (int i = 0; i < money.length; i++) {    //遍历硬币的面值23                 if (j - money[i] >= 0) {24                     int temp = count[j - money[i]] + 1; //当前所需硬币数25                     if (temp < minCoins) {26                         minCoins = temp;27                     }28                 }29             }30 31             count[j] = minCoins;32         }33         System.out.println(Arrays.toString(count));34         return count[sum];35     }36 }

  Python3

 1 #coding=utf-8 2 def charge_making(money, num): 3     &#39;&#39;&#39; 4     找零问题 5     &#39;&#39;&#39; 6     count = [0] * (num + 1) 7     count[0] = 0 8     for j in range(1, num + 1): 9         minCoins = j10         for i in range(len(money)):11             if j - money[i] >= 0:12                 temp = count[j - money[i]] + 113                 if temp < minCoins:14                     minCoins = temp15         16         count[j] = minCoins17     18     return count[num]19 20 money = [1, 3, 2, 5]21 num = 822 count = charge_making(money, num)23 print(count)

tag

#

以上是動態規劃之找零問題詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!

陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn