J 免費餡餅(動態規劃)數塔

2021-08-06 06:25:16 字數 1226 閱讀 2698

都說天上不會掉餡餅,但有一天gameboy正走在回家的小徑上,忽然天上掉下大把大把的餡餅。說來gameboy的人品實在是太好了,這餡餅別處都不掉,就掉落在他身旁的10公尺範圍內。餡餅如果掉在了地上當然就不能吃了,所以gameboy馬上卸下身上的揹包去接。但由於小徑兩側都不能站人,所以他只能在小徑上接。由於gameboy平時老呆在房間裡玩遊戲,雖然在遊戲中是個身手敏捷的高手,但在現實中運動神經特別遲鈍,每秒種只有在移動不超過一公尺的範圍內接住墜落的餡餅。現在給這條小徑如圖示上座標:

為了使問題簡化,假設在接下來的一段時間裡,餡餅都掉落在0-10這11個位置。開始時gameboy站在5這個位置,因此在第一秒,他只能接到4,5,6這三個位置中其中乙個位置上的餡餅。問gameboy最多可能接到多少個餡餅?(假設他的揹包可以容納無窮多個餡餅)

input

輸入資料有多組。每組資料的第一行為以正整數n(0

output

每一組輸入資料對應一行輸出。輸出乙個整數m,表示gameboy最多可能接到m個餡餅。

sample input

6

5 14 1

6 17 2

7 28 3

0

sample output

4
哈哈哈哈哈~~~~開心開心每次自己做出一道題目的時候都開心的樂飛天了~~~~~~

恩 這個題目剛開始看的時候有一點點的亂 不知道怎麼下手  後來想到了數塔的問題  於是就嘗試的寫了下

中間小錯誤不斷不過吧本寶寶嘿嘿自己解決了 

思路就是恩......從後往前推 既然知道了知道最後的是最大值那麼也就一定知道前面那個的最大值依次往前

**上:

#include #include #include #include using namespace std;

int n;

int biscuit[100005][11];

int dp[100005][11];

int wharmax(int a,int b,int c)

for(int j=0;j<=10;j++)

dp[maxn][j]=biscuit[maxn][j];

int g=maxn;

for(i=maxn;i>=1;i--)

} printf("%d\n",wharmax(dp[1][4],dp[1][5],dp[1][6]));

} return 0;

}

數塔 動態規劃 免費餡餅

免費餡餅 這個題是先構建乙個二維陣列,遍歷一遍表,把每個位置餡餅的個數賦值,然後通過倒著遍歷這個表,最後在初始位置的餡餅個數就是最多的餡餅個數 為什麼初始的位置是最大餡餅個數 如圖 紅色代表所能達到的點位,如果在 4,7 處有乙個餡餅,根據題目的規則,是無法到達的,而且,只要餡餅處於紅色區域,根據題...

HDU 1176 免費餡餅 動態規劃 數塔變形

hdu 1176 免費餡餅 簡要分析 1 空間換時間。邊緣陣列多開,不用進行首尾的特殊處理。2 0 不影響結果 如下 include include include include include using namespace std define inf 0x3f3f3f3f define ms...

動態規劃 免費餡餅

由數塔引出。數塔 處於乙個端點,每次可以選擇向左或向右。而每次選擇,取決於,向左能夠得到最大值,還是向右能得到最大值。當到達數塔倒數第二行時,向左還是向右,僅僅取決於,向左的端點數值大還是向右的大。自頂向下思考,自底向上計算。將數塔傾斜,用i,j表示在數塔中位置,dp i j 則表示在為位置 i j...