HDU 數塔DP思維設計

2021-06-22 22:54:48 字數 1580 閱讀 9910

在講述dp

演算法的時候,乙個經典的例子就是數塔問題,它是這樣描述的: 

有如下所示的數塔,要求從頂層走到底層,若每一步只能走到相鄰的結點,則經過的結點的數字之和最大是多少? 

已經告訴你了,這是個dp

的題目,你能ac嗎

? 大神請繞道---不喜勿噴

請自己推狀態方程

第一種:

//數塔

---由上往下

/*#include

#include

#include

#include

#include

#include

using namespace std;                         //核心思想:問題所求值,在第i層第

j個取到最值 

int c,n,dp[105][105];

int main()

while(scanf("%d",&c)!=eof)

while(c--)

scanf("%d",&n);

for(int i=0;ifor(int j=0;j<=i;j++)

scanf("%d",&dp[i][j]);

for(int i=1;i<=n-1;i++)

for(int j=0;j<=i;j++)           //這種資料排列由上往下的話  往往需要考慮邊界問題

if(j==0)

dp[i][j]+=dp[i-1][j];

else if(j==i)

dp[i][j]+=dp[i-1][j-1];

else

dp[i][j]+=max(dp[i-1][j],dp[i-1][j-1]);

sort(dp[n-1],dp[n-1]+n);

/*      for(int i=0;iprintf("%d ",dp[n-1][i]);

printf("\n");  */

/*        printf("%d\n",dp[n-1][n-1]);

return 0;

//由下往上            

/*#include

int main()

int c,n,dp[105][105];

while(scanf("%d",&c)!=eof)      //核心思想:每一次向下求最大和,都取決於下一層、下一層、、、等等

---最後逆向思維 反向考慮  

while(c--)

scanf("%d",&n);

for(int i=0;ifor(int j=0;j<=i;j++)

scanf("%d",&dp[i][j]);

for(int i=n-2;i>=0;i--)

for(int j=0;j<=i;j++)              //由下往上的話  就不需要考慮邊界了 

if(dp[i+1][j]>dp[i+1][j+1])

dp[i][j]+=dp[i+1][j];

else

dp[i][j]+=dp[i+1][j+1];

printf("%d\n",dp[0][0]);

return 0;

HDU 2084 數塔(簡單DP)

hdu 2084 數塔 題意 自上而下,選擇一條累計和最大的路徑 分析 頂點只與左右兩個子節點相關,且子節點路徑的選擇與頂點無關 無後效性 狀態dp i j 表示 i,j 點向下得到的最大累計和 轉移方程 dp i j max dp i 1 j dp i 1 j 1 v i j 核心 for i n...

HDU 1159 DP數塔變形

在一條x軸上,每個點在每個時刻都會有一定數量的餅,問在規定時間內,可以可以最多得到多少餅 就是把矩陣轉化為數塔,在每個時刻的某個位置都有三種可以到達當前位置的可能性 即 左邊,不動,右邊 dp i j 表示第i秒第j位置有多少個餡餅 狀態轉移方程為 dp i j maxi dp i 1 j 1 dp...

HDU2084 數塔(經典dp)

problem description 在講述dp演算法的時候,乙個經典的例子就是數塔問題,它是這樣描述的 有如下所示的數塔,要求從頂層走到底層,若每一步只能走到相鄰的結點,則經過的結點的數字之和最大是多少?已經告訴你了,這是個dp的題目,你能ac嗎?input 輸入資料首先包括乙個整數c,表示測試...