免費餡餅
這個題是先構建乙個二維陣列,遍歷一遍表,把每個位置餡餅的個數賦值,然後通過倒著遍歷這個表,最後在初始位置的餡餅個數就是最多的餡餅個數
為什麼初始的位置是最大餡餅個數:
如圖:紅色代表所能達到的點位,如果在(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...