亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

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

 更新時間:2017年11月29日 09:11:59   作者:SilentKnight  
這篇文章主要介紹了Java動態(tài)規(guī)劃之硬幣找零問題實現(xiàn)代碼,具有一定參考價值,需要的朋友可以了解下。

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

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

問題描述:

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

問題分析:

假設不同的幾組硬幣為數(shù)組coin[0, ..., n-1]. 則求面值k的最少硬幣數(shù)count(k), 那么count函數(shù)和硬幣數(shù)組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的最少硬幣數(shù).

而且具體的過程如下:

* 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代碼實現(xiàn)如下:

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才能存在于數(shù)組matrix中, 才能夠進行回溯.
          matrix[i][j] = matrix[preK][coins.length] + 1;//面值i在進行回溯
          if (matrix[i][coins.length] == 0 || matrix[i][j] < matrix[i][coins.length]) {//如果當前的硬幣數(shù)目是最少的, 更新min列的最少硬幣數(shù)目
            matrix[i][coins.length] = matrix[i][j];
          }
        }
      }
    }
    return matrix[k][coins.length];
  }

代碼經(jīng)過測試, 題目給出的測試用例全部通過!

總結

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

相關文章

  • 淺談java反射和自定義注解的綜合應用實例

    淺談java反射和自定義注解的綜合應用實例

    本篇文章主要介紹了java反射和自定義注解的綜合應用,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2017-09-09
  • springboot3集成mybatis-plus報sqlSession異常的問題解決

    springboot3集成mybatis-plus報sqlSession異常的問題解決

    springboot3已經(jīng)發(fā)布正式版,但是在集成mybatis-plus最新版3.5.2的時候發(fā)現(xiàn)提示異常,本文就來介紹一下報sqlSession異常的問題解決,具有一定的參考價值,感興趣的可以了解一下
    2024-02-02
  • 談談Java 線程池

    談談Java 線程池

    這篇文章主要介紹了Java 線程池的相關資料,幫助大家更好的理解和學習Java,感興趣的朋友可以了解下
    2020-08-08
  • Mybatis日志模塊的適配器模式詳解

    Mybatis日志模塊的適配器模式詳解

    這篇文章主要介紹了Mybatis日志模塊的適配器模式詳解,,mybatis用了適配器模式來兼容這些框架,適配器模式就是通過組合的方式,將需要適配的類轉為使用者能夠使用的接口
    2022-08-08
  • Java 類型相互轉換byte[]類型,Blob類型詳細介紹

    Java 類型相互轉換byte[]類型,Blob類型詳細介紹

    這篇文章主要介紹了Java 類型相互轉換byte[]類型,Blob類型的相關資料,需要的朋友可以參考下
    2016-10-10
  • java獲取ip地址示例

    java獲取ip地址示例

    在JSP里,獲取客戶端的IP地址的方法是:request.getRemoteAddr(),這種方法在大部分情況下都是有效的。但是在通過了Apache,Squid等反向代理軟件就不能獲取到客戶端的真實IP地址了
    2014-04-04
  • 使用Feign調用時添加驗證信息token到請求頭方式

    使用Feign調用時添加驗證信息token到請求頭方式

    這篇文章主要介紹了使用Feign調用時添加驗證信息token到請求頭方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 多線程如何解決for循環(huán)效率的問題

    多線程如何解決for循環(huán)效率的問題

    這篇文章主要介紹了多線程如何解決for循環(huán)效率的問題,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教
    2021-06-06
  • SpringBoot使用RestTemplate實現(xiàn)HTTP請求詳解

    SpringBoot使用RestTemplate實現(xiàn)HTTP請求詳解

    這篇文章主要為大家詳細介紹了SpringBoot如何使用RestTemplate實現(xiàn)進行HTTP請求,文中的示例代碼講解詳細,感興趣的小伙伴可以跟隨小編一起學習一下
    2024-03-03
  • 四步輕松搞定java web每天定時執(zhí)行任務

    四步輕松搞定java web每天定時執(zhí)行任務

    本篇文章主要介紹了四步輕松搞定java web每天定時執(zhí)行任務,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01

最新評論