Java動(dòng)態(tài)規(guī)劃之硬幣找零問(wèn)題實(shí)現(xiàn)代碼
動(dòng)態(tài)規(guī)劃的基本思想是將待求解問(wèn)題分解成若干個(gè)子問(wèn)題,先求解子問(wèn)題,并將這些子問(wèn)題的解保存起來(lái),如果以后在求解較大子問(wèn)題的時(shí)候需要用到這些子問(wèn)題的解,就可以直接取出這些已經(jīng)計(jì)算過(guò)的解而免去重復(fù)運(yùn)算。保存子問(wèn)題的解可以使用填表方式,例如保存在數(shù)組中。
用一個(gè)實(shí)際例子來(lái)體現(xiàn)動(dòng)態(tài)規(guī)劃的算法思想——硬幣找零問(wèn)題。
問(wèn)題描述:
假設(shè)有幾種硬幣,并且數(shù)量無(wú)限。請(qǐng)找出能夠組成某個(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).
問(wèn)題分析:
假設(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])已知, 所以這里又涉及到回溯的問(wèn)題.
所以我們可以創(chuàng)建一個(gè)矩陣matrix[k + 1][coin.length + 1], 使matrix[0][j]全部初始化為0值, 而在matrix[i][coin.length]保存面值為i的最少硬幣數(shù).
而且具體的過(guò)程如下:
* 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) {//回溯法+動(dòng)態(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ò)測(cè)試, 題目給出的測(cè)試用例全部通過(guò)!
總結(jié)
以上就是本文關(guān)于Java動(dòng)態(tài)規(guī)劃之硬幣找零問(wèn)題實(shí)現(xiàn)代碼的全部?jī)?nèi)容,希望對(duì)大家有所幫助。感興趣的朋友可以繼續(xù)參閱本站其他相關(guān)專題。如有不足之處,歡迎留言指出。感謝朋友們對(duì)本站的支持!
- Java動(dòng)態(tài)規(guī)劃之硬幣找零問(wèn)題實(shí)現(xiàn)示例
- Java使用動(dòng)態(tài)規(guī)劃算法思想解決背包問(wèn)題
- Java實(shí)現(xiàn)動(dòng)態(tài)規(guī)劃背包問(wèn)題
- java背包問(wèn)題動(dòng)態(tài)規(guī)劃算法分析
- 背包問(wèn)題-動(dòng)態(tài)規(guī)劃java實(shí)現(xiàn)的分析與代碼
- java動(dòng)態(tài)規(guī)劃算法——硬幣找零問(wèn)題實(shí)例分析
- Java面試之動(dòng)態(tài)規(guī)劃與組合數(shù)
- Java動(dòng)態(tài)規(guī)劃之編輯距離問(wèn)題示例代碼
- Java動(dòng)態(tài)規(guī)劃之丑數(shù)問(wèn)題實(shí)例講解
相關(guān)文章
SpringBoot2整合Ehcache組件實(shí)現(xiàn)輕量級(jí)緩存管理
EhCache是一個(gè)純Java的進(jìn)程內(nèi)緩存框架,具有快速、上手簡(jiǎn)單等特點(diǎn),是Hibernate中默認(rèn)的緩存提供方。本文講述下SpringBoot2 整合Ehcache組件的步驟2021-06-06
Springboot集成任務(wù)調(diào)度實(shí)現(xiàn)過(guò)程
這篇文章主要介紹了Springboot集成任務(wù)調(diào)度實(shí)現(xiàn)過(guò)程,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04
springboot中通過(guò)jwt令牌校驗(yàn)及前端token請(qǐng)求頭進(jìn)行登錄攔截實(shí)戰(zhàn)記錄
這篇文章主要給大家介紹了關(guān)于springboot中如何通過(guò)jwt令牌校驗(yàn)及前端token請(qǐng)求頭進(jìn)行登錄攔截的相關(guān)資料,需要的朋友可以參考下2024-08-08
解決mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò)問(wèn)題
這篇文章主要介紹了mybatis批量更新出現(xiàn)SQL報(bào)錯(cuò),解決辦法也很簡(jiǎn)單只需要在application.properties配置文中的數(shù)據(jù)源url后面添加一個(gè)參數(shù),需要的朋友可以參考下2022-02-02
Spring中的FactoryBean實(shí)現(xiàn)原理詳解
這篇文章主要介紹了Spring中的FactoryBean實(shí)現(xiàn)原理詳解,spring中有兩種類型的Bean,一種是普通的JavaBean,另一種就是工廠Bean(FactoryBean),這兩種Bean都受Spring的IoC容器管理,但它們之間卻有一些區(qū)別,需要的朋友可以參考下2024-02-02
Java 8中Collectors.toMap空指針異常源碼解析
這篇文章主要為大家介紹了Java 8中Collectors.toMap空指針異常源碼解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
MyBatis 執(zhí)行動(dòng)態(tài) SQL語(yǔ)句詳解
大家對(duì)mybatis執(zhí)行任意sql語(yǔ)句都了解,那么MyBatis執(zhí)行動(dòng)態(tài)SQL語(yǔ)句呢?下面腳本之家小編給大家解答下mybatis執(zhí)行動(dòng)態(tài)sql語(yǔ)句的方法,非常不錯(cuò),感興趣的朋友參考下吧2016-08-08
Java中ByteArrayOutputStream亂碼問(wèn)題解決
本文主要介紹了Java中ByteArrayOutputStream亂碼問(wèn)題解決,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2023-07-07
mybatis-plus報(bào)錯(cuò)Not Found TableInfoCache異常問(wèn)題
在集成百度uid-generator過(guò)程中,MyBatis-Plus報(bào)錯(cuò)NotFoundTableInfoCache異常,解決方法:檢查實(shí)體類是否繼承了官方model,確保實(shí)體類對(duì)應(yīng)的mapper已正確注入,在使用@Component注解時(shí),應(yīng)保證相關(guān)依賴已注入2024-09-09

