hdu 1176 免費餡餅

2021-07-26 14:58:56 字數 1068 閱讀 5754

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

sample input

65 1

4 16 1

7 27 2

8 30

sample output

4分析 先計算出總時間,遍歷時間。

i時間 j是格仔。

dp[i][j] 第一維是時間,第二維是位置,第一維為什麼是時間而不是第幾個餡餅,因為餡餅時間是會重複的,而且如果 如果第一維代表第幾個餡餅,那麼要確定的是這個餡餅吃不吃 即加一維0 或者 1 那麼就非常不好推了,所以第一維是時間,而且這個時間是唯一的。

#include

using

namespace std;

#define fi first

#define se second

#define ff(i,a,b) for(int i = a; i <= b; i++)

#define f(i,a,b) for(int i = a; i < b; i++)

typedef pair<

int,

int> pii;

int dp[

100010][

11];#define ll long long

intmain()

for(

int i = maxx -

1; i >=

0; i--

)for

(int j =

0; j <=

10; j++

) cout << dp[0]

[5]<< endl;

}return0;

}

hdu1176 免費餡餅

解題思路 動態規劃 可以看成倒的塔,這個地方轉換過來就快了,狀態轉移方程 d i j max d i 1 j 1 d i 1 j d i 1 j 1 最後答案是d 0 6 ac include include include include include using namespace std d...

hdu1176 免費餡餅

簡單dp 題目要求 求dp 0 5 到dp t 的最大值 類似數塔 只不過1 9號位有三個方向可以選 0和10只有兩個 可將所有的時間段和餡餅看成是乙個矩陣,時間就是行數,掉餡餅的就是列數,則就是數字三角形問題,從最底層找一條路徑,使得路徑上的和最大。dp i j 表示 i 時刻 j位置的最大值 開...

hdu1176 免費餡餅

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