激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - Java動態(tài)規(guī)劃之硬幣找零問題實現代碼

Java動態(tài)規(guī)劃之硬幣找零問題實現代碼

2021-02-23 11:13SilentKnight Java教程

這篇文章主要介紹了Java動態(tài)規(guī)劃之硬幣找零問題實現代碼,具有一定參考價值,需要的朋友可以了解下。

動態(tài)規(guī)劃的基本思想是將待求解問題分解成若干個子問題,先求解子問題,并將這些子問題的解保存起來,如果以后在求解較大子問題的時候需要用到這些子問題的解,就可以直接取出這些已經計算過的解而免去重復運算。保存子問題的解可以使用填表方式,例如保存在數組中。

用一個實際例子來體現動態(tài)規(guī)劃的算法思想——硬幣找零問題。

問題描述:

假設有幾種硬幣,并且數量無限。請找出能夠組成某個數目的找零所使用最少的硬幣數。例如幾種硬幣為[1, 3, 5], 面值2的最少硬幣數為2(1, 1), 面值4的最少硬幣數為2(1, 3), 面值11的最少硬幣數為3(5, 5, 1或者5, 3, 3).

問題分析:

假設不同的幾組硬幣為數組coin[0, ..., n-1]. 則求面值k的最少硬幣數count(k), 那么count函數和硬幣數組coin滿足這樣一個條件:

count(k) = min(count(k - coin[0]), ..., count(k - coin[n - 1])) + 1;
并且在符合條件k - coin[i] >= 0 && k - coin[i] < k的情況下, 前面的公式才成立.
因為k - coin[i] < k的緣故, 那么在求count(k)時, 必須滿足count(i)(i <- [0, k-1])已知, 所以這里又涉及到回溯的問題.

所以我們可以創(chuàng)建一個矩陣matrix[k + 1][coin.length + 1], 使matrix[0][j]全部初始化為0值, 而在matrix[i][coin.length]保存面值為i的最少硬幣數.

而且具體的過程如下:

?
1
2
3
4
5
6
7
8
9
* k|coin 1  3  5  min
  * 0    0  0  0  0
  * 1    1  0  0  1
  * 2    2  0  0  2
  * 3    3  1  0  3, 1
  * 4    2  2  0  2, 2
  * 5    3  3  1  3, 3, 1
  * 6    2  2  2  2, 2, 2
  * ...

最后, 具體的Java代碼實現如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
public static int backTrackingCoin(int[] coins, int k) {//回溯法+動態(tài)規(guī)劃
    if (coins == null || coins.length == 0 || k < 1) {
      return 0;
    }
    int[][] matrix = new int[k + 1][coins.length + 1];
    for (int i = 1; i <= k; i++) {
      for (int j = 0; j < coins.length; j++) {
        int preK = i - coins[j];
        if (preK > -1) {//只有在不小于0時, preK才能存在于數組matrix中, 才能夠進行回溯.
          matrix[i][j] = matrix[preK][coins.length] + 1;//面值i在進行回溯
          if (matrix[i][coins.length] == 0 || matrix[i][j] < matrix[i][coins.length]) {//如果當前的硬幣數目是最少的, 更新min列的最少硬幣數目
            matrix[i][coins.length] = matrix[i][j];
          }
        }
      }
    }
    return matrix[k][coins.length];
  }

代碼經過測試, 題目給出的測試用例全部通過!

總結

以上就是本文關于Java動態(tài)規(guī)劃之硬幣找零問題實現代碼的全部內容,希望對大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關專題。如有不足之處,歡迎留言指出。感謝朋友們對本站的支持!

原文鏈接:http://www.cnblogs.com/littlepanpc/p/7857599.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 久久精品毛片 | 高颜值美女啪啪 | 视频在线色 | 一级黄色a视频 | 日日鲁夜夜视频热线播放 | 91精品久久久久久 | 日韩精品一区不卡 | 狼人狠狠干| 久久精品亚洲欧美日韩精品中文字幕 | 欧美另类视频一区 | 毛片在线播放视频 | 久久免费视频7 | teensexhd| 欧美不卡| 成人福利网 | 亚洲第九十九页 | 精品国产91久久久久久久妲己 | 国产在线精品区 | 双性帝王调教跪撅打屁股 | 在线影院av| 精品亚洲二区 | 成人午夜淫片a | h色视频在线观看 | 久久亚洲线观看视频 | 美女羞羞视频网站 | 亚洲视频综合网 | 欧美日韩一 | h视频免费观看 | 日韩精品一二三 | 日本一区二区视频在线 | 久久免费视频8 | 欧美日本一 | 日本不卡一区二区三区在线 | 亚洲午夜在线 | 深夜影院一级毛片 | 精品一区二区久久久久久久网精 | 国产在线精品91 | 国产精品看片 | 成年免费视频黄网站在线观看 | 亚洲国产高清视频 | 国产免费一区二区三区网站免费 |