HDU 1078 記憶化搜尋

2021-08-01 05:32:39 字數 520 閱讀 7989

乙隻老鼠只能向食物更多的地方走,他一次最多可以走k步,問他最多能吃到多少食物。

第一眼見到這個題,我還以為是個遞推形式的dp,搞了一會,參考了一下題解,才意識到這是乙個很簡單的記憶化搜尋。沒什麼好說的,最常見的記憶化搜尋。

有個細節需要注意一下,就是在記憶化搜尋的時候記得判斷是否越界。

#include

#include

#include

#include

#define maxn 110

using

namespace

std;

int mp[maxn][maxn];

int dp[maxn][maxn];

int n,k;

int dir[4][2]=,,,};

int dfs(int x,int y)

int main()

}printf("%d\n",dfs(0,0));

}return

0;}

hdu 1078 記憶化搜尋

hdu 1078 題意 每次可以朝乙個方向走k格,必須走到乙個數值比當前值大的點,問最多數值加起來能有多少,走到不能再走。一開始定義錯了,定義dp i j 為以 i,j 為終點時所能得到的最大值。dp i t dx j t dy max dp i t dx j t dy dp i j a i t d...

hdu 1078(記憶化搜尋)

題意 老鼠每次最多走k步停下來,停下的這個位置只能比上乙個停留的位置大,並獲取其價值,每次只能水平或垂直走,問最大能得到的價值 解題思路 這道題可以用記憶化搜尋解決,dp i j 表示老鼠在位置 i,j 時可以達到的最優值。因為dp的狀態是乙個有向無環圖,剛開始想會不會走死迴圈,但是這道題有乙個條件...

HDU 1078 記憶化搜尋

題目鏈結 題意是老鼠一開始在 0,0 點,每個點都有乳酪數目,如果老鼠走到 的話就獲得所有乳酪,老鼠只能水平走和垂直走,問怎麼走才能獲得最 酪數。輸入n和k,n是地圖大小,k是老鼠能走多遠。很簡單的一道題,注意超時,記住用記憶化,貌似就因為要記憶化才被hdu歸類進dp的。下面是 include in...