欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Java動態(tài)規(guī)劃之硬幣找零問題實(shí)現(xiàn)示例

 更新時(shí)間:2022年08月04日 10:43:53   作者:程序員小徐同學(xué)  
本文主要介紹了Java動態(tài)規(guī)劃之硬幣找零問題實(shí)現(xiàn)示例,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧

動態(tài)規(guī)劃(dynamic programming)是運(yùn)籌學(xué)的一個(gè)分支,是求解決策過程(decision process)最優(yōu)化的數(shù)學(xué)方法。20世紀(jì)50年代初美國數(shù)學(xué)家R.E.Bellman等人在研究多階段決策過程(multistep decision process)的優(yōu)化問題時(shí),提出了著名的最優(yōu)化原理(principle of optimality),把多階段過程轉(zhuǎn)化為一系列單階段問題,利用各階段之間的關(guān)系,逐個(gè)求解,創(chuàng)立了解決這類過程優(yōu)化問題的新方法–動態(tài)規(guī)劃。1957年出版了他的名著《Dynamic Programming》,這是該領(lǐng)域的第一本著作。

動態(tài)規(guī)劃一般可分為線性動規(guī),區(qū)域動規(guī),樹形動規(guī),背包動規(guī)四類。舉例:線性動規(guī):攔截導(dǎo)彈,合唱隊(duì)形,挖地雷,建學(xué)校,劍客決斗等;區(qū)域動規(guī):石子合并, 加分二叉樹,統(tǒng)計(jì)單詞個(gè)數(shù),炮兵布陣等;樹形動規(guī):貪吃的九頭龍,二分查找樹,聚會的歡樂,數(shù)字三角形等;背包問題:01背包問題,完全背包問題,多重背包問題,分組背包問題,二維背包,裝箱問題,擠牛奶(同濟(jì)ACM第1132題)等;

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

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

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

問題描述:

假設(shè)有幾種硬幣,并且數(shù)量無限。請找出能夠組成某個(gè)數(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è)不同的幾組硬幣為數(shù)組coin[0, ..., n-1]. 則求面值k的最少硬幣數(shù)count(k), 那么count函數(shù)和硬幣數(shù)組coin滿足這樣一個(gè)條件:

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

所以我們可以創(chuàng)建一個(gè)矩陣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代碼實(shí)現(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時(shí), preK才能存在于數(shù)組matrix中, 才能夠進(jìn)行回溯.
          matrix[i][j] = matrix[preK][coins.length] + 1;//面值i在進(jìn)行回溯
          if (matrix[i][coins.length] == 0 || matrix[i][j] < matrix[i][coins.length]) {//如果當(dāng)前的硬幣數(shù)目是最少的, 更新min列的最少硬幣數(shù)目
            matrix[i][coins.length] = matrix[i][j];
          }
        }
      }
    }
    return matrix[k][coins.length];
  }

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

到此這篇關(guān)于Java動態(tài)規(guī)劃之硬幣找零問題實(shí)現(xiàn)示例的文章就介紹到這了,更多相關(guān)Java 硬幣找零內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!

相關(guān)文章

  • Java集合之Map接口與實(shí)現(xiàn)類詳解

    Java集合之Map接口與實(shí)現(xiàn)類詳解

    這篇文章主要為大家詳細(xì)介紹了Java集合中的Map接口與實(shí)現(xiàn)類,文中的示例代碼講解詳細(xì),對我們學(xué)習(xí)Java有一定的幫助,感興趣的可以了解一下
    2022-12-12
  • SpringBoot?+DynamicDataSource切換多數(shù)據(jù)源的全過程

    SpringBoot?+DynamicDataSource切換多數(shù)據(jù)源的全過程

    這篇文章主要介紹了SpringBoot?+DynamicDataSource切換多數(shù)據(jù)源的全過程,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-01-01
  • 詳解SpringBoot Controller接收參數(shù)的幾種常用方式

    詳解SpringBoot Controller接收參數(shù)的幾種常用方式

    這篇文章主要介紹了詳解SpringBoot Controller接收參數(shù)的幾種常用方式,文中通過示例代碼介紹的非常詳細(xì),對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-10-10
  • HashMap和List遍歷方法及如何遍歷刪除元素總結(jié)

    HashMap和List遍歷方法及如何遍歷刪除元素總結(jié)

    在本篇文章中小編給大家分享了關(guān)于HashMap和List遍歷方法及如何遍歷刪除元素知識點(diǎn)總結(jié),需要的朋友們參考下。
    2019-05-05
  • java中給實(shí)體對象屬性的空值賦默認(rèn)值

    java中給實(shí)體對象屬性的空值賦默認(rèn)值

    這篇文章主要介紹了java中給實(shí)體對象屬性的空值賦默認(rèn)值,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 詳解SpringBoot迭代發(fā)布JAR瘦身配置

    詳解SpringBoot迭代發(fā)布JAR瘦身配置

    這篇文章主要介紹了詳解SpringBoot迭代發(fā)布JAR瘦身配置,小編覺得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過來看看吧
    2018-08-08
  • Java時(shí)間類Date類和Calendar類的使用詳解

    Java時(shí)間類Date類和Calendar類的使用詳解

    這篇文章主要介紹了Java時(shí)間類Date類和Calendar類的使用詳解,需要的朋友可以參考下
    2017-08-08
  • SpringCloud全面解析@FeignClient標(biāo)識接口的過程

    SpringCloud全面解析@FeignClient標(biāo)識接口的過程

    這篇文章主要介紹了SpringCloud全面解析@FeignClient標(biāo)識接口的過程,具有很好的參考價(jià)值,希望對大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教
    2022-03-03
  • 如何利用JAVA實(shí)現(xiàn)走迷宮程序

    如何利用JAVA實(shí)現(xiàn)走迷宮程序

    最近經(jīng)常在機(jī)房看同學(xué)在玩一個(gè)走迷宮的游戲,比較有趣,自己也用java實(shí)現(xiàn)了一個(gè),這篇文章主要給大家介紹了關(guān)于如何利用JAVA實(shí)現(xiàn)走迷宮程序的相關(guān)資料,需要的朋友可以參考下
    2021-06-06
  • java使用正則抓取網(wǎng)頁郵箱

    java使用正則抓取網(wǎng)頁郵箱

    這篇文章主要為大家詳細(xì)介紹了java使用正則抓取網(wǎng)頁郵箱的相關(guān)資料,感興趣的小伙伴們可以參考一下
    2016-05-05

最新評論