數塔 動態規劃 免費餡餅

2021-10-08 05:40:21 字數 703 閱讀 9724

免費餡餅

這個題是先構建乙個二維陣列,遍歷一遍表,把每個位置餡餅的個數賦值,然後通過倒著遍歷這個表,最後在初始位置的餡餅個數就是最多的餡餅個數

為什麼初始的位置是最大餡餅個數:

如圖:紅色代表所能達到的點位,如果在(4,7)處有乙個餡餅,根據題目的規則,是無法到達的,而且,只要餡餅處於紅色區域,根據題目規則,都一定可以回溯到起始位置的

這個題還要注意陣列的大小必須大於11,要不然一直過不去(我也不知道為什麼)

#include

#include

#include

#include

using

namespace std;

const

int maxn=

100005

;int dp[maxn][13

];intmmax

(int a,

int b,

int c)

intmain()

for(

int i=min-

1;i>=

0;i--

)else}}

cout<

[5]<

}return0;

}

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

都說天上不會掉餡餅,但有一天gameboy正走在回家的小徑上,忽然天上掉下大把大把的餡餅。說來gameboy的人品實在是太好了,這餡餅別處都不掉,就掉落在他身旁的10公尺範圍內。餡餅如果掉在了地上當然就不能吃了,所以gameboy馬上卸下身上的揹包去接。但由於小徑兩側都不能站人,所以他只能在小徑上接...

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...