動態規劃 湊硬幣 C 實現

2021-07-14 03:02:31 字數 820 閱讀 2086

/*

* file name : dp_coin.cpp

* function : 動態規劃--湊硬幣 c++實現

* created on : 2023年6月28日

* author : [email protected]

任何單位和個人不經本人允許不得用於商業用途

有1元,3元,5元面值的硬幣若干枚,求湊齊11元需要的最小硬幣數.

*/#include #include #pragma warning(disable:4996)

using namespace std;

#define inf 99999

int min(int x, int y, int z);

int main(int argc, char** argv)

; int dp[12] = ;

for (int i = 1; i < 12; i++)

;if (i >= 1)

tmp[0] = dp[i - 1] + 1;

if (i >= 3)

tmp[1] = dp[i - 3] + 1;

if (i >= 5)

tmp[2] = dp[i - 5] + 1;

dp[i] = min(tmp[0], tmp[1], tmp[2]);

cout << "dp["<}

cout << "dp[11]=" << dp[11] << endl;

return 0;

}int min(int x, int y, int z)

動態規劃 湊硬幣

什麼是動態規劃?動態規劃 dynamic programming,簡稱為dp 是運籌學的乙個分支,是求解決策過程 decision process 最優化的數學方法。20世紀50年代初美國數學家r.e.bellman等人在研究多階段決策過程 multistep decision process 的優...

動態規劃演算法 湊硬幣

動態規劃演算法是電腦科學演算法中最重要也是最常用的乙個演算法,巧妙的利用它可以解決很多複雜的問題,另外也頻繁的出現在各大網際網路公司的面試中,因此掌握它是十分必要的。但該演算法對於初學者來說,要想徹底的掌握理解它並非易事,本系列教程將帶領大家一起來學習該演算法,通過經典的案列介紹和解題分析,試圖歸納...

動態規劃 硬幣問題

這是乙個固定重點的最長路和最短路問題,可用動態規劃問題來求解 代表硬幣總值,n代表硬幣總數,v陣列儲存硬幣各個面值,d代表從i出發到結點0的路徑的最長路徑長度或最短路徑長度 vis代表是否訪問過該結點 int n,s,v maxn d maxn vis maxn int dpmax int s re...